Index: tests/SkSLErrorTest.cpp |
diff --git a/tests/SkSLErrorTest.cpp b/tests/SkSLErrorTest.cpp |
index 400ab6dc57d343e16619eb0127b33581c21efc68..5ec73c595b70a4ee213ddf1906802702e22f702a 100644 |
--- a/tests/SkSLErrorTest.cpp |
+++ b/tests/SkSLErrorTest.cpp |
@@ -181,7 +181,7 @@ DEF_TEST(SkSLUsingInvalidValue, r) { |
} |
DEF_TEST(SkSLDifferentReturnType, r) { |
test_failure(r, |
- "int main() { } void main() { }", |
+ "int main() { return 1; } void main() { }", |
"error: 1: functions 'void main()' and 'int main()' differ only in return type\n1 " |
"error\n"); |
} |
@@ -278,3 +278,42 @@ DEF_TEST(SkSLInterfaceBlockStorageModifiers, r) { |
"uniform foo { out int x; };", |
"error: 1: interface block fields may not have storage qualifiers\n1 error\n"); |
} |
+ |
+DEF_TEST(SkSLUseWithoutInitialize, r) { |
+ test_failure(r, |
+ "void main() { int x; if (5 == 2) x = 3; x++; }", |
dogben
2016/10/13 03:55:43
Would be good to add a few more test cases:
1. ex
ethannicholas
2016/10/13 17:41:28
Done.
|
+ "error: 1: 'x' has not been assigned\n1 error\n"); |
+} |
+ |
+DEF_TEST(SkSLUnreachable, r) { |
+ test_failure(r, |
+ "void main() { return; return; }", |
+ "error: 1: unreachable\n1 error\n"); |
+ test_failure(r, |
+ "void main() { for (;;) { continue; int x = 1; } }", |
+ "error: 1: unreachable\n1 error\n"); |
+ test_failure(r, |
+ "void main() { for (;;) { } return; }", |
+ "error: 1: unreachable\n1 error\n"); |
+ test_failure(r, |
+ "void main() { if (true) return; else discard; return; }", |
dogben
2016/10/13 03:55:43
Maybe add this test case: (I think this works corr
ethannicholas
2016/10/13 17:41:28
Done.
|
+ "error: 1: unreachable\n1 error\n"); |
+} |
+ |
+DEF_TEST(SkSLNoReturn, r) { |
+ test_failure(r, |
+ "int foo() { if (2 > 5) return 3; }", |
+ "error: 1: function can exit without returning a value\n1 error\n"); |
+} |
+ |
+DEF_TEST(SkSLBreakOutsideLoop, r) { |
+ test_failure(r, |
+ "void foo() { while(true) {} if (true) break; }", |
+ "error: 1: break statement must be inside a loop\n1 error\n"); |
+} |
+ |
+DEF_TEST(SkSLContinueOutsideLoop, r) { |
+ test_failure(r, |
+ "void foo() { for(;;); continue; }", |
+ "error: 1: continue statement must be inside a loop\n1 error\n"); |
+} |