diff options
Diffstat (limited to 'progs/gallium/python/tests')
| -rwxr-xr-x | progs/gallium/python/tests/base.py | 17 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/surface_copy.py | 16 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/texture_blit.py (renamed from progs/gallium/python/tests/texture_sample.py) | 201 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/texture_transfer.py | 12 | 
4 files changed, 140 insertions, 106 deletions
| diff --git a/progs/gallium/python/tests/base.py b/progs/gallium/python/tests/base.py index bd82f50811..8c55e3ae5d 100755 --- a/progs/gallium/python/tests/base.py +++ b/progs/gallium/python/tests/base.py @@ -43,18 +43,9 @@ from gallium import *  # Enumerate all pixel formats  formats = {}  for name, value in globals().items(): -    if name.startswith("PIPE_FORMAT_") and isinstance(value, int): +    if name.startswith("PIPE_FORMAT_") and isinstance(value, int) and name not in ("PIPE_FORMAT_NONE", "PIPE_FORMAT_COUNT"):          formats[value] = name -def is_depth_stencil_format(format): -    # FIXME: make and use binding to util_format_is_depth_or_stencil -    return format in ( -        PIPE_FORMAT_Z32_UNORM, -        PIPE_FORMAT_S8Z24_UNORM, -        PIPE_FORMAT_X8Z24_UNORM, -        PIPE_FORMAT_Z16_UNORM, -    ) -  def make_image(width, height, rgba):      import Image      outimage = Image.new( @@ -127,16 +118,16 @@ class Test:          self._run(result)          result.summary() -    def assert_rgba(self, surface, x, y, w, h, expected_rgba, pixel_tol=4.0/256, surface_tol=0.85): +    def assert_rgba(self, ctx, surface, x, y, w, h, expected_rgba, pixel_tol=4.0/256, surface_tol=0.85):          total = h*w -        different = surface.compare_tile_rgba(x, y, w, h, expected_rgba, tol=pixel_tol) +        different = ctx.surface_compare_rgba(surface, x, y, w, h, expected_rgba, tol=pixel_tol)          if different:              sys.stderr.write("%u out of %u pixels differ\n" % (different, total))          if float(total - different)/float(total) < surface_tol:              if 0:                  rgba = FloatArray(h*w*4) -                surface.get_tile_rgba(x, y, w, h, rgba) +                ctx.surface_read_rgba(surface, x, y, w, h, rgba)                  show_image(w, h, Result=rgba, Expected=expected_rgba)                  save_image(w, h, rgba, "result.png")                  save_image(w, h, expected_rgba, "expected.png") diff --git a/progs/gallium/python/tests/surface_copy.py b/progs/gallium/python/tests/surface_copy.py index a3f1b3e130..9364fd1110 100755 --- a/progs/gallium/python/tests/surface_copy.py +++ b/progs/gallium/python/tests/surface_copy.py @@ -56,6 +56,7 @@ class TextureTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -99,21 +100,16 @@ class TextureTest(TestCase):          w = dst_surface.width          h = dst_surface.height -        # ??? -        stride = pf_get_stride(texture->format, w) -        size = pf_get_nblocksy(texture->format) * stride +        stride = util_format_get_stride(format, w) +        size = util_format_get_nblocksy(format, h) * stride          src_raw = os.urandom(size) -        src_surface.put_tile_raw(0, 0, w, h, src_raw, stride) +        ctx.surface_write_raw(src_surface, 0, 0, w, h, src_raw, stride) -        ctx = self.dev.context_create() -              ctx.surface_copy(dst_surface, 0, 0,                            src_surface, 0, 0, w, h) -        ctx.flush() - -        dst_raw = dst_surface.get_tile_raw(0, 0, w, h) +        dst_raw = ctx.surface_read_raw(dst_surface, 0, 0, w, h)          if dst_raw != src_raw:              raise TestFailure @@ -122,6 +118,7 @@ class TextureTest(TestCase):  def main():      dev = Device() +    ctx = dev.context_create()      suite = TestSuite()      targets = [ @@ -181,6 +178,7 @@ def main():                              while zslice < depth >> level:                                  test = TextureTest(                                      dev = dev, +                                    ctx = ctx,                                      target = target,                                      format = format,                                       width = size, diff --git a/progs/gallium/python/tests/texture_sample.py b/progs/gallium/python/tests/texture_blit.py index 49545c2e07..a2e62c89ee 100755 --- a/progs/gallium/python/tests/texture_sample.py +++ b/progs/gallium/python/tests/texture_blit.py @@ -28,6 +28,8 @@  ########################################################################## +import random +  from gallium import *  from base import * @@ -115,6 +117,7 @@ class TextureColorSampleTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -125,6 +128,8 @@ class TextureColorSampleTest(TestCase):          face = self.face          level = self.level          zslice = self.zslice +        minz = 0.0 +        maxz = 1.0          tex_usage = PIPE_TEXTURE_USAGE_SAMPLER          geom_flags = 0 @@ -136,8 +141,6 @@ class TextureColorSampleTest(TestCase):          if not dev.is_format_supported(format, target, tex_usage, geom_flags):              raise TestSkip -        ctx = self.dev.context_create() -              # disabled blending/masking          blend = Blend()          blend.rt[0].rgb_src_factor = PIPE_BLENDFACTOR_ONE @@ -155,7 +158,6 @@ class TextureColorSampleTest(TestCase):          rasterizer = Rasterizer()          rasterizer.front_winding = PIPE_WINDING_CW          rasterizer.cull_mode = PIPE_WINDING_NONE -        rasterizer.bypass_vs_clip_and_viewport = 1          ctx.set_rasterizer(rasterizer)          # samplers @@ -183,14 +185,45 @@ class TextureColorSampleTest(TestCase):          )          expected_rgba = FloatArray(height*width*4)  -        texture.get_surface( +        surface = texture.get_surface(              face = face,              level = level,              zslice = zslice, -        ).sample_rgba(expected_rgba) +        ) +         +        ctx.surface_sample_rgba(surface, expected_rgba)          ctx.set_fragment_sampler_texture(0, texture) +        # viewport +        viewport = Viewport() +        scale = FloatArray(4) +        scale[0] = width +        scale[1] = height +        scale[2] = (maxz - minz) / 2.0 +        scale[3] = 1.0 +        viewport.scale = scale +        translate = FloatArray(4) +        translate[0] = 0.0 +        translate[1] = 0.0 +        translate[2] = (maxz - minz) / 2.0 +        translate[3] = 0.0 +        viewport.translate = translate +        ctx.set_viewport(viewport) + +        # scissor +        scissor = Scissor() +        scissor.minx = 0 +        scissor.miny = 0 +        scissor.maxx = width +        scissor.maxy = height +        ctx.set_scissor(scissor) + +        # clip +        clip = Clip() +        clip.nr = 0 +        ctx.set_clip(clip) +          #  framebuffer           cbuf_tex = dev.texture_create(              PIPE_FORMAT_B8G8R8A8_UNORM,  @@ -265,8 +298,8 @@ class TextureColorSampleTest(TestCase):          for i in range(0, 4):              j = 8*i -            verts[j + 0] = pos[i][0] # x -            verts[j + 1] = pos[i][1] # y +            verts[j + 0] = pos[i][0]/float(width) # x +            verts[j + 1] = pos[i][1]/float(height) # y              verts[j + 2] = 0.0 # z              verts[j + 3] = 1.0 # w              verts[j + 4] = tex[i][0] # s @@ -283,7 +316,7 @@ class TextureColorSampleTest(TestCase):          cbuf = cbuf_tex.get_surface() -        self.assert_rgba(cbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85) +        self.assert_rgba(ctx, cbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85)  class TextureDepthSampleTest(TestCase): @@ -302,6 +335,7 @@ class TextureDepthSampleTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -312,6 +346,8 @@ class TextureDepthSampleTest(TestCase):          face = self.face          level = self.level          zslice = self.zslice +        minz = 0.0 +        maxz = 1.0          tex_usage = PIPE_TEXTURE_USAGE_SAMPLER          geom_flags = 0 @@ -323,8 +359,6 @@ class TextureDepthSampleTest(TestCase):          if not dev.is_format_supported(format, target, tex_usage, geom_flags):              raise TestSkip -        ctx = self.dev.context_create() -              # disabled blending/masking          blend = Blend()          blend.rt[0].rgb_src_factor = PIPE_BLENDFACTOR_ONE @@ -345,9 +379,24 @@ class TextureDepthSampleTest(TestCase):          rasterizer = Rasterizer()          rasterizer.front_winding = PIPE_WINDING_CW          rasterizer.cull_mode = PIPE_WINDING_NONE -        rasterizer.bypass_vs_clip_and_viewport = 1          ctx.set_rasterizer(rasterizer) +        # viewport +        viewport = Viewport() +        scale = FloatArray(4) +        scale[0] = width +        scale[1] = height +        scale[2] = (maxz - minz) / 2.0 +        scale[3] = 1.0 +        viewport.scale = scale +        translate = FloatArray(4) +        translate[0] = 0.0 +        translate[1] = 0.0 +        translate[2] = (maxz - minz) / 2.0 +        translate[3] = 0.0 +        viewport.translate = translate +        ctx.set_viewport(viewport) +          # samplers          sampler = Sampler()          sampler.wrap_s = PIPE_TEX_WRAP_CLAMP_TO_EDGE @@ -373,14 +422,29 @@ class TextureDepthSampleTest(TestCase):          )          expected_rgba = FloatArray(height*width*4)  -        texture.get_surface( +        surface = texture.get_surface(              face = face,              level = level,              zslice = zslice, -        ).sample_rgba(expected_rgba) +        ) + +        ctx.surface_sample_rgba(surface, expected_rgba)          ctx.set_fragment_sampler_texture(0, texture) +        # scissor +        scissor = Scissor() +        scissor.minx = 0 +        scissor.miny = 0 +        scissor.maxx = width +        scissor.maxy = height +        ctx.set_scissor(scissor) + +        # clip +        clip = Clip() +        clip.nr = 0 +        ctx.set_clip(clip) +          #  framebuffer           cbuf_tex = dev.texture_create(              PIPE_FORMAT_B8G8R8A8_UNORM,  @@ -464,8 +528,8 @@ class TextureDepthSampleTest(TestCase):          for i in range(0, 4):              j = 8*i -            verts[j + 0] = pos[i][0] # x -            verts[j + 1] = pos[i][1] # y +            verts[j + 0] = pos[i][0]/float(width) # x +            verts[j + 1] = pos[i][1]/float(height) # y              verts[j + 2] = 0.0 # z              verts[j + 3] = 1.0 # w              verts[j + 4] = tex[i][0] # s @@ -482,12 +546,14 @@ class TextureDepthSampleTest(TestCase):          zsbuf = zsbuf_tex.get_surface() -        self.assert_rgba(zsbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85) +        self.assert_rgba(ctx, zsbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85)  def main(): +    random.seed(0xdead3eef) +      dev = Device()      suite = TestSuite() @@ -497,32 +563,9 @@ def main():          PIPE_TEXTURE_3D,      ] -    color_formats = [ -        PIPE_FORMAT_B8G8R8A8_UNORM, -        PIPE_FORMAT_B8G8R8X8_UNORM, -        #PIPE_FORMAT_B8G8R8A8_SRGB, -        PIPE_FORMAT_B5G6R5_UNORM, -        PIPE_FORMAT_B5G5R5A1_UNORM, -        PIPE_FORMAT_B4G4R4A4_UNORM, -        PIPE_FORMAT_A8_UNORM, -        PIPE_FORMAT_L8_UNORM, -        PIPE_FORMAT_UYVY, -        PIPE_FORMAT_DXT1_RGB, -        #PIPE_FORMAT_DXT1_RGBA, -        #PIPE_FORMAT_DXT3_RGBA, -        #PIPE_FORMAT_DXT5_RGBA, -    ] -     -    depth_formats = [ -        PIPE_FORMAT_Z32_UNORM, -        PIPE_FORMAT_S8Z24_UNORM, -        PIPE_FORMAT_X8Z24_UNORM, -        PIPE_FORMAT_Z16_UNORM, -    ] -     -    sizes = [64, 32, 16, 8, 4, 2, 1] +    #sizes = [64, 32, 16, 8, 4, 2, 1]      #sizes = [1020, 508, 252, 62, 30, 14, 6, 3] -    #sizes = [64] +    sizes = [64]      #sizes = [63]      faces = [ @@ -534,45 +577,45 @@ def main():          PIPE_TEX_FACE_NEG_Z,      ] -    for format in color_formats: -        for target in targets: -            for size in sizes: -                if target == PIPE_TEXTURE_3D: -                    depth = size -                else: -                    depth = 1 -                for face in faces: -                    if target != PIPE_TEXTURE_CUBE and face: -                        continue -                    levels = lods(size) -                    for last_level in range(levels): -                        for level in range(0, last_level + 1): -                            zslice = 0 -                            while zslice < depth >> level: -                                test = TextureColorSampleTest( -                                    dev = dev, -                                    target = target, -                                    format = format,  -                                    width = size, -                                    height = size, -                                    depth = depth, -                                    last_level = last_level, -                                    face = face, -                                    level = level, -                                    zslice = zslice, -                                ) -                                suite.add_test(test) -                                zslice = (zslice + 1)*2 - 1 -    for format in depth_formats: -        target = PIPE_TEXTURE_2D -        depth = 1 -        face = 0 -        last_level = 0 -        level = 0 -        zslice = 0 -        for size in sizes: -            test = TextureDepthSampleTest( +    ctx = dev.context_create() + +    n = 10000 +     +    for i in range(n): +        format = random.choice(formats.keys()) +        if not util_format_is_depth_or_stencil(format): +            is_depth_or_stencil = util_format_is_depth_or_stencil(format) + +            if is_depth_or_stencil: +                target = PIPE_TEXTURE_2D +            else: +                target = random.choice(targets) +             +            size = random.choice(sizes) + +            if target == PIPE_TEXTURE_3D: +                depth = size +            else: +                depth = 1 + +            if target == PIPE_TEXTURE_CUBE: +                face =random.choice(faces) +            else: +                face = PIPE_TEX_FACE_POS_X + +            levels = lods(size) +            last_level = random.randint(0, levels - 1) +            level = random.randint(0, last_level) +            zslice = random.randint(0, max(depth >> level, 1) - 1) + +            if is_depth_or_stencil: +                klass = TextureDepthSampleTest +            else: +                klass = TextureColorSampleTest + +            test = klass(                  dev = dev, +                ctx = ctx,                  target = target,                  format = format,                   width = size, diff --git a/progs/gallium/python/tests/texture_transfer.py b/progs/gallium/python/tests/texture_transfer.py index 7da00e4255..97a28e01a4 100755 --- a/progs/gallium/python/tests/texture_transfer.py +++ b/progs/gallium/python/tests/texture_transfer.py @@ -59,6 +59,7 @@ class TextureTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -86,15 +87,14 @@ class TextureTest(TestCase):          surface = texture.get_surface(face, level, zslice) -        # ??? -        stride = pf_get_stride(texture->format, w) -        size = pf_get_nblocksy(texture->format) * stride +        stride = util_format_get_stride(format, width) +        size = util_format_get_nblocksy(format, height) * stride          in_raw = os.urandom(size) -        surface.put_tile_raw(0, 0, surface.width, surface.height, in_raw, stride) +        ctx.surface_write_raw(surface, 0, 0, surface.width, surface.height, in_raw, stride) -        out_raw = surface.get_tile_raw(0, 0, surface.width, surface.height) +        out_raw = ctx.surface_read_raw(surface, 0, 0, surface.width, surface.height)          if in_raw != out_raw:              raise TestFailure @@ -102,6 +102,7 @@ class TextureTest(TestCase):  def main():      dev = Device() +    ctx = dev.context_create()      suite = TestSuite()      targets = [ @@ -161,6 +162,7 @@ def main():                              while zslice < depth >> level:                                  test = TextureTest(                                      dev = dev, +                                    ctx = ctx,                                      target = target,                                      format = format,                                       width = size, | 
