Mac OS X 1.6.1
- Chrome 14
- Firefox 5.0, 5.0.1
- Safari 5.0.5
- Opera 11.50
- Chrome 14
- Internet Explorer 9
- Chrome 14
- Opera 11.50
- Firefox 4.0, 5.0.1
- Safari 5.0.5
- Internet Explorer 8.0
- Built-in Android Browser
With your help, I would like to expand this list. With the navigation manager in particular, I would be much happier with a broader browser and platform spread.
Running the Tests
If you're willing to help out by running the tests on a platform that isn't listed above, or even by confirming one of the listed platforms, doing so is easy. Relief's "deps.js" file expects that Closure Library is checked out into a folder called "closure-library/", and that Relief is checked out into the same parent directory under the name "relief/". To run the tests from a blank slate:
cd /devel (or wherever you like to do your development)
svn checkout http://closure-library.googlecode.com/svn/trunk closure-library
svn checkout http://relief.googlecode.com/svn/trunk relief
python -m SimpleHTTPServer
svn checkout http://closure-library.googlecode.com/svn/trunk closure-library
svn checkout http://relief.googlecode.com/svn/trunk relief
python -m SimpleHTTPServer
The above navigates to whatever directory you like, checks out the latest Closure Library revision, checks out the latest Relief revision, and then runs an HTTP server in the current directory. You can test against whatever version you like as long as the Library directory is called "closure-library/". Likewise, Relief expects that its root directory is "relief/".
Once you have the latest revisions and the HTTP server is running, point your browser to http://localhost:8000/relief/relief/all_tests.html. You should see a multi-test runner like you do for the Closure Library tests (http://closure-library.googlecode.com/svn/trunk/all_tests.html). Click Start and watch them go. If you notice any tests fail, please create an issue at http://code.google.com/p/relief/issues. Please provide as much information as you can think of, specifically:
- Browser
- Operating System
- Closure Library revision
- Relief revision
- Specific error or test failure messages
- The name of the test(s) that failed
Internet Explorer 8
When I ran the tests on IE 8, none of the test cases auto-discovered the test functions, so all tests failed. After some poking around, I found that goog.testing.TestCase class uses something called the "RuntimeObject" (goog.global['RuntimeObject']) instead of searching directly on goog.global. testcase.js explains this by saying "...on IE we look in the little known RuntimeObject which holds references to all globals". This is not a problem when running the Closure Library tests because they declare their tests as simple function statements:
function testLibrary() { assertNotUndefined("'goog' not loaded", goog); }In Relief, tests are declared a little differently to allow for more easily-read test names:
var $ = window; $['test getCommandID returns the given ID'] = function() { var cmd = createCommand(); assertEquals('getCommandID returned an incorrect ID.', commandID, cmd.getCommandID()); };This works well in all browsers (even IE9) except IE8. It turns out that, for some reason, the RuntimeObject does not pick up the global function properties defined on the "window" object. If the test declarations are changed to simple function expressions, they are properly picked up. I ran the tests on IE8 by temporarily changing the goog.testing.TestCase.getGlobals function to simply return goog.global. This works just fine.
No comments:
Post a Comment