X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=padding_effect_test.cpp;h=5fa0e42a77235bae2777476bbe34f928ef62408e;hp=8c05a1e65c89f5b77c25c60e6d57ad94f54dc302;hb=81f33379cabb7cf8b47f2d2bd3892f853afc89ab;hpb=e92a5ffa19eb67b4db5af1db8559630139073668 diff --git a/padding_effect_test.cpp b/padding_effect_test.cpp index 8c05a1e..5fa0e42 100644 --- a/padding_effect_test.cpp +++ b/padding_effect_test.cpp @@ -1,6 +1,6 @@ -// Unit tests for AlphaMultiplicationEffect. +// Unit tests for PaddingEffect. -#include +#include #include #include "effect_chain.h" @@ -26,7 +26,7 @@ TEST(PaddingEffectTest, SimpleCenter) { }; float out_data[4 * 4]; - EffectChainTester tester(NULL, 4, 4); + EffectChainTester tester(nullptr, 4, 4); ImageFormat format; format.color_space = COLORSPACE_sRGB; @@ -59,7 +59,7 @@ TEST(PaddingEffectTest, WhiteBorderColor) { }; float out_data[4 * 4]; - EffectChainTester tester(NULL, 4, 4); + EffectChainTester tester(nullptr, 4, 4); ImageFormat format; format.color_space = COLORSPACE_sRGB; @@ -92,7 +92,7 @@ TEST(PaddingEffectTest, BorderColorIsInLinearGamma) { }; float out_data[4 * 2]; - EffectChainTester tester(NULL, 1, 2); + EffectChainTester tester(nullptr, 1, 2); ImageFormat format; format.color_space = COLORSPACE_sRGB; @@ -126,7 +126,7 @@ TEST(PaddingEffectTest, DifferentXAndYOffset) { }; float out_data[3 * 3]; - EffectChainTester tester(NULL, 3, 3); + EffectChainTester tester(nullptr, 3, 3); ImageFormat format; format.color_space = COLORSPACE_sRGB; @@ -150,15 +150,13 @@ TEST(PaddingEffectTest, NonIntegerOffset) { float data[4 * 1] = { 0.25f, 0.50f, 0.75f, 1.0f, }; - // Note that the first pixel is completely blank, since the cutoff goes - // at the immediate left of the texel. float expected_data[5 * 2] = { - 0.0f, 0.4375f, 0.6875f, 0.9375f, 0.0f, + 0.1875f, 0.4375f, 0.6875f, 0.9375f, 0.25f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, }; float out_data[5 * 2]; - EffectChainTester tester(NULL, 5, 2); + EffectChainTester tester(nullptr, 5, 2); ImageFormat format; format.color_space = COLORSPACE_sRGB; @@ -188,7 +186,7 @@ TEST(PaddingEffectTest, Crop) { }; float out_data[1 * 1]; - EffectChainTester tester(NULL, 1, 1); + EffectChainTester tester(nullptr, 1, 1); ImageFormat format; format.color_space = COLORSPACE_sRGB; @@ -208,51 +206,56 @@ TEST(PaddingEffectTest, Crop) { expect_equal(expected_data, out_data, 1, 1); } -TEST(PaddingEffectTest, CropFromBottom) { - float data[2 * 2] = { - 1.0f, 0.5f, - 0.8f, 0.3f, +TEST(PaddingEffectTest, AlphaIsCorrectEvenWithNonLinearInputsAndOutputs) { + float data[2 * 1] = { + 1.0f, + 0.8f, }; - float expected_data[1 * 1] = { - 0.5f, + float expected_data[4 * 4] = { + 1.0f, 1.0f, 1.0f, 0.5f, + 1.0f, 1.0f, 1.0f, 1.0f, + 0.8f, 0.8f, 0.8f, 1.0f, + 1.0f, 1.0f, 1.0f, 0.5f, }; - float out_data[1 * 1]; + float out_data[4 * 4]; - EffectChainTester tester(NULL, 1, 1); + EffectChainTester tester(nullptr, 1, 4); ImageFormat format; - format.color_space = COLORSPACE_sRGB; - format.gamma_curve = GAMMA_LINEAR; + format.color_space = COLORSPACE_REC_601_625; + format.gamma_curve = GAMMA_REC_709; - FlatInput *input = new FlatInput(format, FORMAT_GRAYSCALE, GL_FLOAT, 2, 2); + FlatInput *input = new FlatInput(format, FORMAT_GRAYSCALE, GL_FLOAT, 1, 2); input->set_pixel_data(data); tester.get_chain()->add_input(input); Effect *effect = tester.get_chain()->add_effect(new PaddingEffect()); CHECK(effect->set_int("width", 1)); - CHECK(effect->set_int("height", 1)); - CHECK(effect->set_float("left", -1.0f)); - CHECK(effect->set_float("top", -1.0f)); - CHECK(effect->set_int("pad_from_bottom", 1)); + CHECK(effect->set_int("height", 4)); + CHECK(effect->set_float("left", 0.0f)); + CHECK(effect->set_float("top", 1.0f)); - tester.run(out_data, GL_RED, COLORSPACE_sRGB, GAMMA_LINEAR, OUTPUT_ALPHA_FORMAT_PREMULTIPLIED); - expect_equal(expected_data, out_data, 1, 1); + RGBATuple border_color(1.0f, 1.0f, 1.0f, 0.5f); + CHECK(effect->set_vec4("border_color", (float *)&border_color)); + + tester.run(out_data, GL_RGBA, COLORSPACE_REC_601_625, GAMMA_REC_709, OUTPUT_ALPHA_FORMAT_POSTMULTIPLIED); + expect_equal(expected_data, out_data, 4, 4); } -TEST(PaddingEffectTest, AlphaIsCorrectEvenWithNonLinearInputsAndOutputs) { +TEST(PaddingEffectTest, RedBorder) { // Not black nor white, but still a saturated primary. float data[2 * 1] = { 1.0f, 0.8f, }; float expected_data[4 * 4] = { - 1.0f, 1.0f, 1.0f, 0.5f, + 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 1.0f, 1.0f, 1.0f, 0.8f, 0.8f, 0.8f, 1.0f, - 1.0f, 1.0f, 1.0f, 0.5f, + 1.0f, 0.0f, 0.0f, 1.0f, }; float out_data[4 * 4]; - EffectChainTester tester(NULL, 1, 4); + EffectChainTester tester(nullptr, 1, 4); ImageFormat format; format.color_space = COLORSPACE_REC_601_625; @@ -268,11 +271,79 @@ TEST(PaddingEffectTest, AlphaIsCorrectEvenWithNonLinearInputsAndOutputs) { CHECK(effect->set_float("left", 0.0f)); CHECK(effect->set_float("top", 1.0f)); - RGBATuple border_color(1.0f, 1.0f, 1.0f, 0.5f); + RGBATuple border_color(1.0f, 0.0f, 0.0f, 1.0f); CHECK(effect->set_vec4("border_color", (float *)&border_color)); - tester.run(out_data, GL_RGBA, COLORSPACE_REC_601_625, GAMMA_REC_709, OUTPUT_ALPHA_FORMAT_POSTMULTIPLIED); + tester.run(out_data, GL_RGBA, COLORSPACE_REC_709, GAMMA_REC_709, OUTPUT_ALPHA_FORMAT_POSTMULTIPLIED); expect_equal(expected_data, out_data, 4, 4); } +TEST(PaddingEffectTest, BorderOffsetTopAndBottom) { + float data[2 * 2] = { + 1.0f, 0.5f, + 0.8f, 0.3f, + }; + float expected_data[4 * 4] = { + 0.0f, 0.000f, 0.000f, 0.0f, + 0.0f, 0.750f, 0.375f, 0.0f, + 0.0f, 0.800f, 0.300f, 0.0f, + 0.0f, 0.200f, 0.075f, 0.0f, // Repeated pixels, 25% opacity. + }; + float out_data[4 * 4]; + + EffectChainTester tester(nullptr, 4, 4); + + ImageFormat format; + format.color_space = COLORSPACE_sRGB; + format.gamma_curve = GAMMA_LINEAR; + + FlatInput *input = new FlatInput(format, FORMAT_GRAYSCALE, GL_FLOAT, 2, 2); + input->set_pixel_data(data); + tester.get_chain()->add_input(input); + + Effect *effect = tester.get_chain()->add_effect(new PaddingEffect()); + CHECK(effect->set_int("width", 4)); + CHECK(effect->set_int("height", 4)); + CHECK(effect->set_float("left", 1.0f)); + CHECK(effect->set_float("top", 1.0f)); + CHECK(effect->set_float("border_offset_top", 0.25f)); + CHECK(effect->set_float("border_offset_bottom", 0.25f)); + + tester.run(out_data, GL_RED, COLORSPACE_sRGB, GAMMA_LINEAR, OUTPUT_ALPHA_FORMAT_PREMULTIPLIED); + expect_equal(expected_data, out_data, 4, 4); +} + +TEST(PaddingEffectTest, BorderOffsetLeftAndRight) { + float data[3 * 2] = { + 1.0f, 0.5f, 0.6f, + 0.8f, 0.3f, 0.2f, + }; + float expected_data[4 * 2] = { + 0.750f, 0.5f, 0.3f, 0.0f, + 0.600f, 0.3f, 0.1f, 0.0f + }; + float out_data[4 * 2]; + + EffectChainTester tester(nullptr, 4, 2); + + ImageFormat format; + format.color_space = COLORSPACE_sRGB; + format.gamma_curve = GAMMA_LINEAR; + + FlatInput *input = new FlatInput(format, FORMAT_GRAYSCALE, GL_FLOAT, 3, 2); + input->set_pixel_data(data); + tester.get_chain()->add_input(input); + + Effect *effect = tester.get_chain()->add_effect(new PaddingEffect()); + CHECK(effect->set_int("width", 4)); + CHECK(effect->set_int("height", 2)); + CHECK(effect->set_float("left", 0.0f)); + CHECK(effect->set_float("top", 0.0f)); + CHECK(effect->set_float("border_offset_left", 0.25f)); + CHECK(effect->set_float("border_offset_right", -0.5f)); + + tester.run(out_data, GL_RED, COLORSPACE_sRGB, GAMMA_LINEAR, OUTPUT_ALPHA_FORMAT_PREMULTIPLIED); + expect_equal(expected_data, out_data, 4, 2); +} + } // namespace movit