test_rtti.odin 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. package test_internal
  2. import "core:fmt"
  3. import "core:testing"
  4. Buggy_Struct :: struct {
  5. a: int,
  6. b: bool,
  7. c: [3]^string,
  8. }
  9. #assert(size_of(Buggy_Struct) == 40)
  10. g_buggy: Buggy_Struct = {}
  11. EXPECTED_REPR := "%!s(Buggy_Struct=Buggy_Struct{a = 0, b = false, c = [0x0, 0x0, 0x0]})"
  12. @test
  13. rtti_test :: proc(t: ^testing.T) {
  14. l_buggy: Buggy_Struct = {}
  15. g_b := ([^]u8)(&g_buggy)[:size_of(Buggy_Struct)]
  16. l_b := ([^]u8)(&l_buggy)[:size_of(Buggy_Struct)]
  17. {
  18. checksum := 0
  19. for v, i in g_b {
  20. checksum += (i+1) * int(v)
  21. }
  22. testing.expectf(t, checksum == 0, "Expected g_b to be zero-initialized, got %v", g_b)
  23. }
  24. {
  25. checksum := 0
  26. for v, i in l_b {
  27. checksum += (i+1) * int(v)
  28. }
  29. testing.expectf(t, checksum == 0, "Expected l_b to be zero-initialized, got %v", l_b)
  30. }
  31. testing.expectf(t, size_of(Buggy_Struct) == 40, "Expected size_of(Buggy_Struct) == 40, got %v", size_of(Buggy_Struct))
  32. testing.expectf(t, size_of(g_buggy) == 40, "Expected size_of(g_buggy) == 40, got %v", size_of(g_buggy))
  33. testing.expectf(t, size_of(l_buggy) == 40, "Expected size_of(l_buggy) == 40, got %v", size_of(l_buggy))
  34. g_s := fmt.tprintf("%s", g_buggy)
  35. l_s := fmt.tprintf("%s", l_buggy)
  36. testing.expectf(t, g_s == EXPECTED_REPR, "Expected fmt.tprintf(\"%%s\", g_s)) to return \"%v\", got \"%v\"", EXPECTED_REPR, g_s)
  37. testing.expectf(t, l_s == EXPECTED_REPR, "Expected fmt.tprintf(\"%%s\", l_s)) to return \"%v\", got \"%v\"", EXPECTED_REPR, l_s)
  38. }