Index: third_party/closure_compiler/compiler_test.py |
diff --git a/third_party/closure_compiler/compiler_customization_test.py b/third_party/closure_compiler/compiler_test.py |
similarity index 66% |
rename from third_party/closure_compiler/compiler_customization_test.py |
rename to third_party/closure_compiler/compiler_test.py |
index 9873c8fe6c9018b8b19649ae7183a4f432108db9..effd68a8c728748c96d832d26f3405649ddc1016 100755 |
--- a/third_party/closure_compiler/compiler_customization_test.py |
+++ b/third_party/closure_compiler/compiler_test.py |
@@ -21,7 +21,7 @@ _POLYMER_EXTERNS = os.path.join(_SRC_DIR, "third_party", "polymer", "v0_8", |
"polymer.externs.js") |
-class CompilerCustomizationTest(unittest.TestCase): |
+class CompilerTest(unittest.TestCase): |
_ASSERT_DEFINITION = Processor(_ASSERT_JS).contents |
_CR_DEFINE_DEFINITION = Processor(_CR_JS).contents |
_CR_UI_DECORATE_DEFINITION = Processor(_CR_UI_JS).contents |
@@ -29,24 +29,57 @@ class CompilerCustomizationTest(unittest.TestCase): |
def setUp(self): |
self._checker = Checker() |
Dan Beam
2015/05/19 18:23:33
def tearDown(self):
# remove all files regardles
Theresa
2015/05/19 19:21:02
Done.
|
- def _runChecker(self, source_code): |
+ def _runChecker(self, source_code, output_wrapper=None): |
file_path = "/script.js" |
FileCache._cache[file_path] = source_code |
- return self._checker.check(file_path, externs=[_POLYMER_EXTERNS]) |
+ out_file, out_map = self._createOutFiles() |
+ |
+ found_errors, stderr = self._checker.check(file_path, |
+ externs=[_POLYMER_EXTERNS], |
+ out_file=out_file, |
+ output_wrapper=output_wrapper) |
+ return found_errors, stderr, out_file, out_map |
def _runCheckerTestExpectError(self, source_code, expected_error): |
- _, stderr = self._runChecker(source_code) |
+ _, stderr, out_file, out_map = self._runChecker(source_code) |
self.assertTrue(expected_error in stderr, |
msg="Expected chunk: \n%s\n\nOutput:\n%s\n" % ( |
expected_error, stderr)) |
+ self.assertFalse(os.path.exists(out_file)) |
+ self.assertFalse(os.path.exists(out_map)) |
- def _runCheckerTestExpectSuccess(self, source_code): |
- found_errors, stderr = self._runChecker(source_code) |
+ def _runCheckerTestExpectSuccess(self, source_code, expected_output=None, |
+ output_wrapper=None): |
+ found_errors, stderr, out_file, out_map = self._runChecker(source_code, |
+ output_wrapper) |
self.assertFalse(found_errors, |
msg="Expected success, but got failure\n\nOutput:\n%s\n" % stderr) |
+ self.assertTrue(os.path.exists(out_map)) |
+ self.assertTrue(os.path.exists(out_file)) |
+ if expected_output: |
+ with open(out_file, 'r') as file: |
Dan Beam
2015/05/19 18:23:33
' -> " everywhere feasible
Theresa
2015/05/19 19:21:02
Done.
|
+ self.assertEquals(file.read(), expected_output) |
+ |
+ self._removeFiles([out_file, out_map]) |
+ |
+ def _createOutFiles(self): |
Dan Beam
2015/05/19 18:23:32
why do we need this? shouldn't they be created by
Theresa
2015/05/19 18:29:23
The directory is created in main if it doesn't alr
Theresa
2015/05/19 19:21:02
Done.
Dan Beam
2015/05/20 02:01:00
why not move this to check() instead of main()?
ht
Dan Beam
2015/05/20 02:05:33
sorry, make a _ensure_out_file_exists() (or someth
Theresa
2015/05/20 02:07:37
I moved it to _run_js_check() since it's not actua
|
+ out_file = "/tmp/gen/script.js" |
+ out_map = "/tmp/gen/script.js.map" |
+ |
+ out_dir = os.path.dirname(out_file) |
+ if not os.path.exists(out_dir): |
+ os.makedirs(out_dir) |
+ |
+ return out_file, out_map |
+ |
+ def _removeFiles(self, files): |
+ for file in files: |
+ if(os.path.exists(file)): |
Dan Beam
2015/05/19 18:23:33
the python gods do not approve of your c-like synt
Theresa
2015/05/19 19:21:02
Done.
|
+ os.remove(file) |
+ |
def testGetInstance(self): |
self._runCheckerTestExpectError(""" |
var cr = { |
@@ -235,6 +268,52 @@ function f() { |
} |
""") |
+ def testValidScriptCompilation(self): |
+ self._runCheckerTestExpectSuccess(""" |
+var testScript = function() { console.log("hello world") };""", |
Dan Beam
2015/05/19 18:23:33
can you put some \n in here so the difference is l
Theresa
2015/05/19 19:21:02
Done.
|
+"""'use strict';var testScript=function(){console.log("hello world")};\n""") |
Dan Beam
2015/05/19 18:23:33
hmmm, why is 'use strict'; prepended?
Theresa
2015/05/19 18:29:23
Because the closure compiler always prepends it? I
Theresa
2015/05/19 19:21:01
I'm going to guess it's from the _COMMON_CLOSURE_A
|
+ |
+ def testOutputWrapper(self): |
+ self._runCheckerTestExpectSuccess(""" |
Dan Beam
2015/05/19 18:23:33
indent off
Theresa
2015/05/19 19:21:01
Done.
|
+var testScript = function() { console.log("hello world") }; |
+""", """(function(){'use strict';var testScript=function()""" |
++ """{console.log("hello world")};})();\n""", |
+output_wrapper="(function(){%output%})();") |
Dan Beam
2015/05/19 18:23:33
make this prettier
Theresa
2015/05/19 19:21:01
Done.
|
+ |
+ def testCheckMultiple(self): |
+ source_file = "/tmp/script.js" |
Dan Beam
2015/05/19 18:23:32
this should use tempfile instead
https://docs.pyth
Theresa
2015/05/19 19:21:01
Done.
|
+ with open(source_file, 'w') as f: |
+ f.write(""" |
Dan Beam
2015/05/19 18:23:33
why are we actually writing these files rather tha
Theresa
2015/05/19 18:29:22
I tried using FileCache._chache and the jar failed
Theresa
2015/05/19 19:21:01
Tried again and it still failed. I think the diffe
|
+goog.require('testScript'); |
+ |
+testScript(); |
+""") |
+ |
+ source_file2 = "/tmp/script2.js" |
+ with open(source_file2, 'w') as f: |
+ f.write(""" |
+goog.provide('testScript'); |
+ |
+var testScript = function(){}; |
+""") |
Dan Beam
2015/05/19 18:23:33
can you reverse the order of source_file/source_fi
Theresa
2015/05/19 19:21:01
Done.
|
+ |
+ out_file, out_map = self._createOutFiles() |
+ sources = [source_file, source_file2] |
+ externs = [_POLYMER_EXTERNS] |
+ found_errors, stderr = self._checker.check_multiple(sources, |
+ externs=externs, |
+ out_file=out_file) |
+ self.assertFalse(found_errors, |
+ msg="Expected success, but got failure\n\nOutput:\n%s\n" % stderr) |
+ |
+ expected_output = "'use strict';var testScript=function(){};testScript();\n" |
+ self.assertTrue(os.path.exists(out_map)) |
+ self.assertTrue(os.path.exists(out_file)) |
+ with open(out_file, 'r') as file: |
+ self.assertEquals(file.read(), expected_output) |
+ |
+ self._removeFiles([source_file, source_file2, out_file, out_map]) |
+ |
if __name__ == "__main__": |
unittest.main() |