diff options
| -rw-r--r-- | .gitignore | 1 | ||||
| -rw-r--r-- | jsTestDriver-jquery.conf | 2 | ||||
| -rw-r--r-- | jsTestDriver.conf | 2 | ||||
| -rw-r--r-- | lib/jasmine-1.0.1/MIT.LICENSE | 20 | ||||
| -rw-r--r-- | lib/jasmine-1.0.1/jasmine-html.js | 188 | ||||
| -rw-r--r-- | lib/jasmine-1.0.1/jasmine.css | 166 | ||||
| -rw-r--r-- | lib/jasmine-1.0.1/jasmine.js (renamed from lib/jasmine/jasmine-1.0.1.js) | 0 | ||||
| -rw-r--r-- | lib/jasmine/.DS_Store | bin | 6148 -> 0 bytes | |||
| -rwxr-xr-x | server.sh | 2 | ||||
| -rw-r--r-- | src/scenario/Scenario.js | 8 | ||||
| -rw-r--r-- | test/manual.html | 103 | ||||
| -rw-r--r-- | test/testabilityPatch.js | 15 | ||||
| -rw-r--r-- | test/widgetsSpec.js | 6 | 
13 files changed, 498 insertions, 15 deletions
| @@ -1,3 +1,4 @@  build/  angularjs.netrc  jstd.log +.DS_Store
\ No newline at end of file diff --git a/jsTestDriver-jquery.conf b/jsTestDriver-jquery.conf index add64fa0..7f0d6912 100644 --- a/jsTestDriver-jquery.conf +++ b/jsTestDriver-jquery.conf @@ -1,7 +1,7 @@  server: http://localhost:9876  load: -  - lib/jasmine/jasmine-1.0.1.js +  - lib/jasmine-1.0.1/jasmine.js    - lib/jasmine-jstd-adapter/JasmineAdapter.js    - lib/jquery/jquery-1.4.2.js    - test/jquery_alias.js diff --git a/jsTestDriver.conf b/jsTestDriver.conf index 87d25a86..f7b6646a 100644 --- a/jsTestDriver.conf +++ b/jsTestDriver.conf @@ -1,7 +1,7 @@  server: http://localhost:9876  load: -  - lib/jasmine/jasmine-1.0.1.js +  - lib/jasmine-1.0.1/jasmine.js    - lib/jasmine-jstd-adapter/JasmineAdapter.js    - lib/jquery/jquery-1.4.2.js    - test/jquery_remove.js diff --git a/lib/jasmine-1.0.1/MIT.LICENSE b/lib/jasmine-1.0.1/MIT.LICENSE new file mode 100644 index 00000000..1eb9b49e --- /dev/null +++ b/lib/jasmine-1.0.1/MIT.LICENSE @@ -0,0 +1,20 @@ +Copyright (c) 2008-2010 Pivotal Labs + +Permission is hereby granted, free of charge, to any person obtaining +a copy of this software and associated documentation files (the +"Software"), to deal in the Software without restriction, including +without limitation the rights to use, copy, modify, merge, publish, +distribute, sublicense, and/or sell copies of the Software, and to +permit persons to whom the Software is furnished to do so, subject to +the following conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/lib/jasmine-1.0.1/jasmine-html.js b/lib/jasmine-1.0.1/jasmine-html.js new file mode 100644 index 00000000..81402b9c --- /dev/null +++ b/lib/jasmine-1.0.1/jasmine-html.js @@ -0,0 +1,188 @@ +jasmine.TrivialReporter = function(doc) { +  this.document = doc || document; +  this.suiteDivs = {}; +  this.logRunningSpecs = false; +}; + +jasmine.TrivialReporter.prototype.createDom = function(type, attrs, childrenVarArgs) { +  var el = document.createElement(type); + +  for (var i = 2; i < arguments.length; i++) { +    var child = arguments[i]; + +    if (typeof child === 'string') { +      el.appendChild(document.createTextNode(child)); +    } else { +      if (child) { el.appendChild(child); } +    } +  } + +  for (var attr in attrs) { +    if (attr == "className") { +      el[attr] = attrs[attr]; +    } else { +      el.setAttribute(attr, attrs[attr]); +    } +  } + +  return el; +}; + +jasmine.TrivialReporter.prototype.reportRunnerStarting = function(runner) { +  var showPassed, showSkipped; + +  this.outerDiv = this.createDom('div', { className: 'jasmine_reporter' }, +      this.createDom('div', { className: 'banner' }, +        this.createDom('div', { className: 'logo' }, +            this.createDom('a', { href: 'http://pivotal.github.com/jasmine/', target: "_blank" }, "Jasmine"), +            this.createDom('span', { className: 'version' }, runner.env.versionString())), +        this.createDom('div', { className: 'options' }, +            "Show ", +            showPassed = this.createDom('input', { id: "__jasmine_TrivialReporter_showPassed__", type: 'checkbox' }), +            this.createDom('label', { "for": "__jasmine_TrivialReporter_showPassed__" }, " passed "), +            showSkipped = this.createDom('input', { id: "__jasmine_TrivialReporter_showSkipped__", type: 'checkbox' }), +            this.createDom('label', { "for": "__jasmine_TrivialReporter_showSkipped__" }, " skipped") +            ) +          ), + +      this.runnerDiv = this.createDom('div', { className: 'runner running' }, +          this.createDom('a', { className: 'run_spec', href: '?' }, "run all"), +          this.runnerMessageSpan = this.createDom('span', {}, "Running..."), +          this.finishedAtSpan = this.createDom('span', { className: 'finished-at' }, "")) +      ); + +  this.document.body.appendChild(this.outerDiv); + +  var suites = runner.suites(); +  for (var i = 0; i < suites.length; i++) { +    var suite = suites[i]; +    var suiteDiv = this.createDom('div', { className: 'suite' }, +        this.createDom('a', { className: 'run_spec', href: '?spec=' + encodeURIComponent(suite.getFullName()) }, "run"), +        this.createDom('a', { className: 'description', href: '?spec=' + encodeURIComponent(suite.getFullName()) }, suite.description)); +    this.suiteDivs[suite.id] = suiteDiv; +    var parentDiv = this.outerDiv; +    if (suite.parentSuite) { +      parentDiv = this.suiteDivs[suite.parentSuite.id]; +    } +    parentDiv.appendChild(suiteDiv); +  } + +  this.startedAt = new Date(); + +  var self = this; +  showPassed.onclick = function(evt) { +    if (showPassed.checked) { +      self.outerDiv.className += ' show-passed'; +    } else { +      self.outerDiv.className = self.outerDiv.className.replace(/ show-passed/, ''); +    } +  }; + +  showSkipped.onclick = function(evt) { +    if (showSkipped.checked) { +      self.outerDiv.className += ' show-skipped'; +    } else { +      self.outerDiv.className = self.outerDiv.className.replace(/ show-skipped/, ''); +    } +  }; +}; + +jasmine.TrivialReporter.prototype.reportRunnerResults = function(runner) { +  var results = runner.results(); +  var className = (results.failedCount > 0) ? "runner failed" : "runner passed"; +  this.runnerDiv.setAttribute("class", className); +  //do it twice for IE +  this.runnerDiv.setAttribute("className", className); +  var specs = runner.specs(); +  var specCount = 0; +  for (var i = 0; i < specs.length; i++) { +    if (this.specFilter(specs[i])) { +      specCount++; +    } +  } +  var message = "" + specCount + " spec" + (specCount == 1 ? "" : "s" ) + ", " + results.failedCount + " failure" + ((results.failedCount == 1) ? "" : "s"); +  message += " in " + ((new Date().getTime() - this.startedAt.getTime()) / 1000) + "s"; +  this.runnerMessageSpan.replaceChild(this.createDom('a', { className: 'description', href: '?'}, message), this.runnerMessageSpan.firstChild); + +  this.finishedAtSpan.appendChild(document.createTextNode("Finished at " + new Date().toString())); +}; + +jasmine.TrivialReporter.prototype.reportSuiteResults = function(suite) { +  var results = suite.results(); +  var status = results.passed() ? 'passed' : 'failed'; +  if (results.totalCount == 0) { // todo: change this to check results.skipped +    status = 'skipped'; +  } +  this.suiteDivs[suite.id].className += " " + status; +}; + +jasmine.TrivialReporter.prototype.reportSpecStarting = function(spec) { +  if (this.logRunningSpecs) { +    this.log('>> Jasmine Running ' + spec.suite.description + ' ' + spec.description + '...'); +  } +}; + +jasmine.TrivialReporter.prototype.reportSpecResults = function(spec) { +  var results = spec.results(); +  var status = results.passed() ? 'passed' : 'failed'; +  if (results.skipped) { +    status = 'skipped'; +  } +  var specDiv = this.createDom('div', { className: 'spec '  + status }, +      this.createDom('a', { className: 'run_spec', href: '?spec=' + encodeURIComponent(spec.getFullName()) }, "run"), +      this.createDom('a', { +        className: 'description', +        href: '?spec=' + encodeURIComponent(spec.getFullName()), +        title: spec.getFullName() +      }, spec.description)); + + +  var resultItems = results.getItems(); +  var messagesDiv = this.createDom('div', { className: 'messages' }); +  for (var i = 0; i < resultItems.length; i++) { +    var result = resultItems[i]; + +    if (result.type == 'log') { +      messagesDiv.appendChild(this.createDom('div', {className: 'resultMessage log'}, result.toString())); +    } else if (result.type == 'expect' && result.passed && !result.passed()) { +      messagesDiv.appendChild(this.createDom('div', {className: 'resultMessage fail'}, result.message)); + +      if (result.trace.stack) { +        messagesDiv.appendChild(this.createDom('div', {className: 'stackTrace'}, result.trace.stack)); +      } +    } +  } + +  if (messagesDiv.childNodes.length > 0) { +    specDiv.appendChild(messagesDiv); +  } + +  this.suiteDivs[spec.suite.id].appendChild(specDiv); +}; + +jasmine.TrivialReporter.prototype.log = function() { +  var console = jasmine.getGlobal().console; +  if (console && console.log) { +    if (console.log.apply) { +      console.log.apply(console, arguments); +    } else { +      console.log(arguments); // ie fix: console.log.apply doesn't exist on ie +    } +  } +}; + +jasmine.TrivialReporter.prototype.getLocation = function() { +  return this.document.location; +}; + +jasmine.TrivialReporter.prototype.specFilter = function(spec) { +  var paramMap = {}; +  var params = this.getLocation().search.substring(1).split('&'); +  for (var i = 0; i < params.length; i++) { +    var p = params[i].split('='); +    paramMap[decodeURIComponent(p[0])] = decodeURIComponent(p[1]); +  } + +  if (!paramMap["spec"]) return true; +  return spec.getFullName().indexOf(paramMap["spec"]) == 0; +}; diff --git a/lib/jasmine-1.0.1/jasmine.css b/lib/jasmine-1.0.1/jasmine.css new file mode 100644 index 00000000..6583fe7c --- /dev/null +++ b/lib/jasmine-1.0.1/jasmine.css @@ -0,0 +1,166 @@ +body { +  font-family: "Helvetica Neue Light", "Lucida Grande", "Calibri", "Arial", sans-serif; +} + + +.jasmine_reporter a:visited, .jasmine_reporter a { +  color: #303;  +} + +.jasmine_reporter a:hover, .jasmine_reporter a:active { +  color: blue;  +} + +.run_spec { +  float:right; +  padding-right: 5px; +  font-size: .8em; +  text-decoration: none; +} + +.jasmine_reporter { +  margin: 0 5px; +} + +.banner { +  color: #303; +  background-color: #fef; +  padding: 5px; +} + +.logo { +  float: left; +  font-size: 1.1em; +  padding-left: 5px; +} + +.logo .version { +  font-size: .6em; +  padding-left: 1em; +} + +.runner.running { +  background-color: yellow; +} + + +.options { +  text-align: right; +  font-size: .8em; +} + + + + +.suite { +  border: 1px outset gray; +  margin: 5px 0; +  padding-left: 1em; +} + +.suite .suite { +  margin: 5px;  +} + +.suite.passed { +  background-color: #dfd; +} + +.suite.failed { +  background-color: #fdd; +} + +.spec { +  margin: 5px; +  padding-left: 1em; +  clear: both; +} + +.spec.failed, .spec.passed, .spec.skipped { +  padding-bottom: 5px; +  border: 1px solid gray; +} + +.spec.failed { +  background-color: #fbb; +  border-color: red; +} + +.spec.passed { +  background-color: #bfb; +  border-color: green; +} + +.spec.skipped { +  background-color: #bbb; +} + +.messages { +  border-left: 1px dashed gray; +  padding-left: 1em; +  padding-right: 1em; +} + +.passed { +  background-color: #cfc; +  display: none; +} + +.failed { +  background-color: #fbb; +} + +.skipped { +  color: #777; +  background-color: #eee; +  display: none; +} + + +/*.resultMessage {*/ +  /*white-space: pre;*/ +/*}*/ + +.resultMessage span.result { +  display: block; +  line-height: 2em; +  color: black; +} + +.resultMessage .mismatch { +  color: black; +} + +.stackTrace { +  white-space: pre; +  font-size: .8em; +  margin-left: 10px; +  max-height: 5em; +  overflow: auto; +  border: 1px inset red; +  padding: 1em; +  background: #eef; +} + +.finished-at { +  padding-left: 1em; +  font-size: .6em; +} + +.show-passed .passed, +.show-skipped .skipped { +  display: block; +} + + +#jasmine_content { +  position:fixed; +  right: 100%; +} + +.runner { +  border: 1px solid gray; +  display: block; +  margin: 5px 0; +  padding: 2px 0 2px 10px; +} diff --git a/lib/jasmine/jasmine-1.0.1.js b/lib/jasmine-1.0.1/jasmine.js index 964f99ed..964f99ed 100644 --- a/lib/jasmine/jasmine-1.0.1.js +++ b/lib/jasmine-1.0.1/jasmine.js diff --git a/lib/jasmine/.DS_Store b/lib/jasmine/.DS_StoreBinary files differ deleted file mode 100644 index 5008ddfc..00000000 --- a/lib/jasmine/.DS_Store +++ /dev/null @@ -1 +1 @@ -java -jar lib/jstestdriver/JsTestDriver.jar --port 9876 +java -jar lib/jstestdriver/JsTestDriver.jar --port 9876 --browserTimeout 20000 diff --git a/src/scenario/Scenario.js b/src/scenario/Scenario.js index 17252d0d..c00ed3dd 100644 --- a/src/scenario/Scenario.js +++ b/src/scenario/Scenario.js @@ -193,13 +193,6 @@ function browserTrigger(element, type) {        case 'checkbox':          element.checked = !element.checked;          break; -      case 'text': -      case 'textarea': -      case 'password': -        // TODO: FIX THIS HACK -        // for some reason on IE 'change' event does not fire in -        // jQuery but keyup does. So we are hacking it! -        type = 'keyup';      }      element.fireEvent('on' + type);    } else { @@ -229,3 +222,4 @@ function browserTrigger(element, type) {      return parentTrigger.apply(this, arguments);    };  })(_jQuery.fn); + diff --git a/test/manual.html b/test/manual.html new file mode 100644 index 00000000..3b1886f3 --- /dev/null +++ b/test/manual.html @@ -0,0 +1,103 @@ +<!DOCTYPE HTML> +<html> +<head> +  <title>Jasmine Test Runner</title> +  <link rel="stylesheet" type="text/css" href="../lib/jasmine-1.0.1/jasmine.css"> +  <script type="text/javascript" src="../lib/jasmine-1.0.1/jasmine.js"></script> +  <script type="text/javascript" src="../lib/jasmine-1.0.1/jasmine-html.js"></script> + + +  <!-- include source files here... --> +  <script type="text/javascript" src="../lib/jquery/jquery-1.4.2.js"></script> +  <script type="text/javascript"> var _jQuery = $;</script> + +  <script type="text/javascript" src="../src/Angular.js"></script> +  <script type="text/javascript" src="../src/JSON.js"></script> +  <script type="text/javascript" src="../src/Compiler.js"></script> +  <script type="text/javascript" src="../src/Scope.js"></script> +  <script type="text/javascript" src="../src/Injector.js"></script> +  <script type="text/javascript" src="../src/jqLite.js"></script> +  <script type="text/javascript" src="../src/parser.js"></script> +  <script type="text/javascript" src="../src/Resource.js"></script> +  <script type="text/javascript" src="../src/Browser.js"></script> +  <script type="text/javascript" src="../src/AngularPublic.js"></script> +  <script type="text/javascript" src="../src/services.js"></script> +  <script type="text/javascript" src="../src/apis.js"></script> +  <script type="text/javascript" src="../src/filters.js"></script> +  <script type="text/javascript" src="../src/formatters.js"></script> +  <script type="text/javascript" src="../src/validators.js"></script> +  <script type="text/javascript" src="../src/directives.js"></script> +  <script type="text/javascript" src="../src/markups.js"></script> +  <script type="text/javascript" src="../src/widgets.js"></script> + +  <script type="text/javascript" src="../src/scenario/Scenario.js"></script> +  <script type="text/javascript" src="../src/scenario/Application.js"></script> +  <script type="text/javascript" src="../src/scenario/Describe.js"></script> +  <script type="text/javascript" src="../src/scenario/Future.js"></script> +  <script type="text/javascript" src="../src/scenario/HtmlUI.js"></script> +  <script type="text/javascript" src="../src/scenario/Runner.js"></script> +  <script type="text/javascript" src="../src/scenario/SpecRunner.js"></script> +  <script type="text/javascript" src="../src/scenario/dsl.js"></script> +  <script type="text/javascript" src="../src/scenario/matchers.js"></script> + +  <script type="text/javascript" src="angular-mocks.js"></script> +  <script type="text/javascript" src="testabilityPatch.js"></script> + +  <!-- include spec files here... --> +<script type="text/javascript"> +describe('manual', function(){ +  var scope; + +  function compile(html, initialScope, parent) { +    var compiler = new Compiler(angularTextMarkup, angularAttrMarkup, angularDirective, angularWidget); +    var element = self.element = jqLite(html); +    scope = compiler.compile(element)(element); + +    if (parent) parent.append(element); + +    extend(scope, initialScope); +    scope.$init(); +    return {node:element, scope:scope}; +  }; + +  it('should debug', function(){ +    var x = compile( +        '<select name="selection" ng:format="number">' + +        '<option value="{{$index}}" ng:repeat="name in [\'A\', \'B\', \'C\']">{{name}}</option>' + +      '</select>'); +    expect(scope.selection).toEqual(undefined); + +    browserTrigger(element[0].childNodes[2], 'change'); +    expect(scope.selection).toEqual(1); + +    scope.selection = 2; +    scope.$eval(); +    expect(element[0].childNodes[3].selected).toEqual(true); +  }); + +  it('should reproduce', function(){ +    var select = $('<select name=""><option>a</option></select>'); +    var log = ''; +    select.bind('change', function(){ log += 'change;'; }); +    select.bind('click', function(){ log += 'click;'; }); +    select.bind('keyup', function(){ log += 'keyup;'; }); +    select[0].attachEvent('onchange', function(){ log += 'CHANGE;';}); +    select[0].fireEvent('onfocusout'); +    select[0].fireEvent('onchange'); +    select[0].fireEvent('onclick'); +    select[0].fireEvent('onkeyup'); +    expect(log).toEqual('CHANGE;change;click;keyup;'); +  }); +}); +</script> + +</head> +<body> + +<script type="text/javascript"> +  jasmine.getEnv().addReporter(new jasmine.TrivialReporter()); +  jasmine.getEnv().execute(); +</script> + +</body> +</html> diff --git a/test/testabilityPatch.js b/test/testabilityPatch.js index 247faa19..b4602c39 100644 --- a/test/testabilityPatch.js +++ b/test/testabilityPatch.js @@ -1,5 +1,16 @@ -jstd = jstestdriver; -dump = bind(jstd.console, jstd.console.log); +/** + * Here is the problem: http://bugs.jquery.com/ticket/7292 + * basically jQuery treats change event on some browsers (IE) as a + * special event and changes it form 'change' to 'click/keyup' and + * few others. This horrible hack removes the special treatment + */ +_jQuery.event.special.change = undefined; + + +if (window.jstestdriver) { +  jstd = jstestdriver; +  dump = bind(jstd.console, jstd.console.log); +}  beforeEach(function(){    this.addMatchers({ diff --git a/test/widgetsSpec.js b/test/widgetsSpec.js index c0cdd565..df0941c0 100644 --- a/test/widgetsSpec.js +++ b/test/widgetsSpec.js @@ -345,9 +345,9 @@ describe("widget", function(){        it('should initialize to selected', function(){          compile(              '<select name="selection">' + -            '<option>A</option>' + -            '<option selected>B</option>' + -        '</select>'); +                '<option>A</option>' + +                '<option selected>B</option>' + +            '</select>');          expect(scope.selection).toEqual('B');          scope.selection = 'A';          scope.$eval(); | 
