|
@@ -0,0 +1,50 @@
|
|
|
|
+package test_core_odin_parser
|
|
|
|
+
|
|
|
|
+import "core:testing"
|
|
|
|
+import "core:fmt"
|
|
|
|
+
|
|
|
|
+import "core:odin/parser"
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+TEST_count := 0
|
|
|
|
+TEST_fail := 0
|
|
|
|
+
|
|
|
|
+when ODIN_TEST {
|
|
|
|
+ expect :: testing.expect
|
|
|
|
+ log :: testing.log
|
|
|
|
+} else {
|
|
|
|
+ expect :: proc(t: ^testing.T, condition: bool, message: string, loc := #caller_location) {
|
|
|
|
+ fmt.printf("[%v] ", loc)
|
|
|
|
+ TEST_count += 1
|
|
|
|
+ if !condition {
|
|
|
|
+ TEST_fail += 1
|
|
|
|
+ fmt.println(message)
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ fmt.println(" PASS")
|
|
|
|
+ }
|
|
|
|
+ log :: proc(t: ^testing.T, v: any, loc := #caller_location) {
|
|
|
|
+ fmt.printf("[%v] ", loc)
|
|
|
|
+ fmt.printf("log: %v\n", v)
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+main :: proc() {
|
|
|
|
+ t := testing.T{}
|
|
|
|
+ test_parse_demo(&t)
|
|
|
|
+
|
|
|
|
+ fmt.printf("%v/%v tests successful.\n", TEST_count - TEST_fail, TEST_count)
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+@test
|
|
|
|
+test_parse_demo :: proc(t: ^testing.T) {
|
|
|
|
+ pkg, ok := parser.parse_package_from_path("examples/demo")
|
|
|
|
+
|
|
|
|
+ expect(t, ok == true, "parser.parse_package_from_path failed")
|
|
|
|
+
|
|
|
|
+ for key, value in pkg.files {
|
|
|
|
+ expect(t, value.syntax_error_count == 0, fmt.tprintf("%v should contain zero errors", key))
|
|
|
|
+ }
|
|
|
|
+}
|