test_rtti.odin 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. package test_internal_rtti
  2. import "core:fmt"
  3. import "core:mem"
  4. import "core:os"
  5. import "core:testing"
  6. Buggy_Struct :: struct {
  7. a: int,
  8. b: bool,
  9. c: [3]^string,
  10. }
  11. #assert(size_of(Buggy_Struct) == 40)
  12. g_buggy: Buggy_Struct = {}
  13. EXPECTED_REPR := "%!s(Buggy_Struct=Buggy_Struct{a = 0, b = false, c = [0x0, 0x0, 0x0]})"
  14. @test
  15. rtti_test :: proc(t: ^testing.T) {
  16. l_buggy: Buggy_Struct = {}
  17. g_b := ([^]u8)(&g_buggy)[:size_of(Buggy_Struct)]
  18. l_b := ([^]u8)(&l_buggy)[:size_of(Buggy_Struct)]
  19. {
  20. checksum := 0
  21. for v, i in g_b {
  22. checksum += (i+1) * int(v)
  23. }
  24. expect(t, checksum == 0, fmt.tprintf("Expected g_b to be zero-initialized, got %v", g_b))
  25. }
  26. {
  27. checksum := 0
  28. for v, i in l_b {
  29. checksum += (i+1) * int(v)
  30. }
  31. expect(t, checksum == 0, fmt.tprintf("Expected l_b to be zero-initialized, got %v", l_b))
  32. }
  33. expect(t, size_of(Buggy_Struct) == 40, fmt.tprintf("Expected size_of(Buggy_Struct) == 40, got %v", size_of(Buggy_Struct)))
  34. expect(t, size_of(g_buggy) == 40, fmt.tprintf("Expected size_of(g_buggy) == 40, got %v", size_of(g_buggy)))
  35. expect(t, size_of(l_buggy) == 40, fmt.tprintf("Expected size_of(l_buggy) == 40, got %v", size_of(l_buggy)))
  36. g_s := fmt.tprintf("%s", g_buggy)
  37. l_s := fmt.tprintf("%s", l_buggy)
  38. expect(t, g_s == EXPECTED_REPR, fmt.tprintf("Expected fmt.tprintf(\"%%s\", g_s)) to return \"%v\", got \"%v\"", EXPECTED_REPR, g_s))
  39. expect(t, l_s == EXPECTED_REPR, fmt.tprintf("Expected fmt.tprintf(\"%%s\", l_s)) to return \"%v\", got \"%v\"", EXPECTED_REPR, l_s))
  40. }
  41. // -------- -------- -------- -------- -------- -------- -------- -------- -------- --------
  42. main :: proc() {
  43. t := testing.T{}
  44. mem_track_test(&t, rtti_test)
  45. fmt.printf("%v/%v tests successful.\n", TEST_count - TEST_fail, TEST_count)
  46. if TEST_fail > 0 {
  47. os.exit(1)
  48. }
  49. }
  50. mem_track_test :: proc(t: ^testing.T, test: proc(t: ^testing.T)) {
  51. track: mem.Tracking_Allocator
  52. mem.tracking_allocator_init(&track, context.allocator)
  53. context.allocator = mem.tracking_allocator(&track)
  54. test(t)
  55. expect(t, len(track.allocation_map) == 0, "Expected no leaks.")
  56. expect(t, len(track.bad_free_array) == 0, "Expected no leaks.")
  57. for _, leak in track.allocation_map {
  58. fmt.printf("%v leaked %v bytes\n", leak.location, leak.size)
  59. }
  60. for bad_free in track.bad_free_array {
  61. fmt.printf("%v allocation %p was freed badly\n", bad_free.location, bad_free.memory)
  62. }
  63. }
  64. TEST_count := 0
  65. TEST_fail := 0
  66. when ODIN_TEST {
  67. expect :: testing.expect
  68. log :: testing.log
  69. } else {
  70. expect :: proc(t: ^testing.T, condition: bool, message: string, loc := #caller_location) {
  71. TEST_count += 1
  72. if !condition {
  73. TEST_fail += 1
  74. fmt.printf("[%v] %v\n", loc, message)
  75. return
  76. }
  77. }
  78. log :: proc(t: ^testing.T, v: any, loc := #caller_location) {
  79. fmt.printf("[%v] ", loc)
  80. fmt.printf("log: %v\n", v)
  81. }
  82. }