diff --git a/README.markdown b/README.markdown index d469e77..8ddf9ae 100644 --- a/README.markdown +++ b/README.markdown @@ -347,6 +347,8 @@ There are spy-specfic matchers that are very handy. `wasNotCalledWith(arguments)` returns true if the object is a spy and was not called with the passed arguments +Spies can be trained to respond in a variety of ways when invoked: + `andCallThrough()`: spies on AND calls the original function spied on `andReturn(arguments)`: returns passed arguments when spy is called @@ -355,6 +357,8 @@ There are spy-specfic matchers that are very handy. `andCallFake(function)`: calls passed function when spy is called +Spies have some useful properties: + `callCount`: returns number of times spy was called `mostRecentCall.args`: returns argument array from last call to spy. diff --git a/Rakefile b/Rakefile index bcadfe1..64d7cdb 100644 --- a/Rakefile +++ b/Rakefile @@ -2,7 +2,7 @@ desc 'Builds lib/jasmine from source' task :build do # these files must be better - sources = ["src/base.js", "src/util.js", "src/Env.js"] + sources = ["src/base.js", "src/util.js", "src/Env.js", "src/ActionCollection.js", "src/Reporter.js"] sources += Dir.glob('src/*.js').reject{|f| sources.include?(f)} diff --git a/doc/files.html b/doc/files.html index 997edb9..b997fff 100644 --- a/doc/files.html +++ b/doc/files.html @@ -190,12 +190,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -211,151 +219,7 @@ ul.inheritsList
    -

    src/ActionCollection.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/base.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/Env.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/Matchers.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/mock-timeout.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/NestedResults.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/PrettyPrinter.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/QueuedFunction.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/Reporters.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/Runner.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/Spec.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/Suite.js

    - -
    - - - - -
    -
    -
    - -
    -

    src/util.js

    +

    lib/jasmine.js

    @@ -370,7 +234,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    \ No newline at end of file diff --git a/doc/index.html b/doc/index.html index 3f9122f..c9123ec 100644 --- a/doc/index.html +++ b/doc/index.html @@ -190,12 +190,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -228,6 +236,18 @@ ul.inheritsList
    +
    +

    jasmine.Env

    + +
    +
    + +
    +

    jasmine.MultiReporter

    + +
    +
    +

    jasmine.NestedResults

    @@ -240,12 +260,24 @@ ul.inheritsList

    +
    +

    jasmine.Reporter

    + +
    +
    +

    jasmine.Runner


    +
    +

    jasmine.Spec

    + +
    +
    +

    jasmine.Spy

    @@ -268,7 +300,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    \ No newline at end of file diff --git a/doc/symbols/_global_.html b/doc/symbols/_global_.html index 9945918..e831a25 100644 --- a/doc/symbols/_global_.html +++ b/doc/symbols/_global_.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -381,7 +389,7 @@ ul.inheritsList Used for restoring any state that is hijacked during spec execution.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -422,7 +430,7 @@ Used for restoring any state that is hijacked during spec execution. Used for spec setup, including validating assumptions.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -465,7 +473,7 @@ are accessible by calls to beforeEach, it, and afterEach. Describe blocks can be of setup in some tests.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -519,7 +527,7 @@ It is passed an Object that is the actual value and should chain to one of the m jasmine.Matchers functions.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -560,7 +568,7 @@ jasmine.Matchers functions. // TODO: pending tests
    - Defined in: base.js. + Defined in: jasmine.js. @@ -611,7 +619,7 @@ jasmine.Matchers functions. Defines part of a jasmine spec. Used in cominbination with waits or waitsFor in asynchrnous specs.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -650,7 +658,7 @@ jasmine.Matchers functions. Function that installs a spy on an existing object's method name. Used within a Spec to create a spy.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -699,7 +707,7 @@ spyOn(foo, 'not'); // actual foo.not will not be called, execution stops
    See:
    -
    jasmine.createSpy
    +
    jasmine.createSpy
    @@ -717,7 +725,7 @@ spyOn(foo, 'not'); // actual foo.not will not be called, execution stops Waits for a timeout before moving to the next runs()-defined block.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -756,7 +764,7 @@ spyOn(foo, 'not'); // actual foo.not will not be called, execution stops Waits for the latchFunction to return true before proceeding to the next runs()-defined block.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -807,7 +815,7 @@ spyOn(foo, 'not'); // actual foo.not will not be called, execution stops Disables a suite of specifications. Used to disable some suites in a file, or files, temporarily during development.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -854,7 +862,7 @@ spyOn(foo, 'not'); // actual foo.not will not be called, execution stops A convenience method that allows existing specs to be disabled temporarily during development.
    - Defined in: base.js. + Defined in: jasmine.js. @@ -900,7 +908,7 @@ A convenience method that allows existing specs to be disabled temporarily durin
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:05 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:18 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.ActionCollection.html b/doc/symbols/jasmine.ActionCollection.html index 3a3920c..4b6af94 100644 --- a/doc/symbols/jasmine.ActionCollection.html +++ b/doc/symbols/jasmine.ActionCollection.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: ActionCollection.js. +
    Defined in: jasmine.js.

    @@ -309,15 +317,6 @@ ul.inheritsList - -   - -
    waitForDone(action) -
    -
    - - - @@ -353,7 +352,7 @@ ul.inheritsList
    Parameters:
    - {jasmine.Env} env + {jasmine.Env} env
    @@ -477,42 +476,6 @@ ul.inheritsList -
    - - -
    - - - waitForDone(action) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - action - -
    -
    - -
    - - - - - - - - @@ -527,7 +490,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:05 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:18 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.Env.html b/doc/symbols/jasmine.Env.html index e675c98..75ebb40 100644 --- a/doc/symbols/jasmine.Env.html +++ b/doc/symbols/jasmine.Env.html @@ -197,12 +197,18 @@ ul.inheritsList
  • jasmine.Env
  • +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -228,7 +234,7 @@ ul.inheritsList -
    Defined in: Env.js. +
    Defined in: jasmine.js.

    @@ -249,7 +255,7 @@ ul.inheritsList
    jasmine.Env()
    -
    Env
    +
    Environment for Jasmine
    @@ -276,108 +282,9 @@ ul.inheritsList   -
    addEqualityTester(equalityTester) +
    addReporter(reporter)
    -
    - - - - -   - -
    afterEach(afterEachFunction) -
    -
    - - - - -   - -
    beforeEach(beforeEachFunction) -
    -
    - - - - -   - -
    compareObjects_(a, b, mismatchKeys, mismatchValues) -
    -
    - - - - -   - -
    contains_(haystack, needle) -
    -
    - - - - -   - -
    describe(description, specDefinitions) -
    -
    - - - - -   - -
    equals_(a, b, mismatchKeys, mismatchValues) -
    -
    - - - - -   - -
    execute() -
    -
    - - - - -   - -
    it(description, func) -
    -
    - - - - -   - -
    specFilter() -
    -
    - - - - -   - -
    xdescribe(desc, specDefinitions) -
    -
    - - - - -   - -
    xit(desc, func) -
    -
    +
    Register a reporter to receive status updates from Jasmine.
    @@ -402,7 +309,7 @@ ul.inheritsList
    - Env + Environment for Jasmine
    @@ -429,15 +336,15 @@ ul.inheritsList Method Detail - +
    - addEqualityTester(equalityTester) + addReporter(reporter)
    - + Register a reporter to receive status updates from Jasmine.
    @@ -449,450 +356,10 @@ ul.inheritsList
    Parameters:
    - equalityTester + {jasmine.Reporter} reporter
    -
    - - - - - - - - - - -
    - - -
    - - - afterEach(afterEachFunction) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - afterEachFunction - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - beforeEach(beforeEachFunction) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - beforeEachFunction - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - compareObjects_(a, b, mismatchKeys, mismatchValues) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - a - -
    -
    - -
    - b - -
    -
    - -
    - mismatchKeys - -
    -
    - -
    - mismatchValues - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - contains_(haystack, needle) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - haystack - -
    -
    - -
    - needle - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - describe(description, specDefinitions) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - description - -
    -
    - -
    - specDefinitions - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - equals_(a, b, mismatchKeys, mismatchValues) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - a - -
    -
    - -
    - b - -
    -
    - -
    - mismatchKeys - -
    -
    - -
    - mismatchValues - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - execute() - -
    -
    - - - -
    - - - - - - - - - - - -
    - - -
    - - - it(description, func) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - description - -
    -
    - -
    - func - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - specFilter() - -
    -
    - - - -
    - - - - - - - - - - - -
    - - -
    - - - xdescribe(desc, specDefinitions) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - desc - -
    -
    - -
    - specDefinitions - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - xit(desc, func) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - desc - -
    -
    - -
    - func - -
    -
    +
    An object which will receive status updates.
    @@ -917,7 +384,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 09:15:39 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.MultiReporter.html b/doc/symbols/jasmine.MultiReporter.html new file mode 100644 index 0000000..b50324f --- /dev/null +++ b/doc/symbols/jasmine.MultiReporter.html @@ -0,0 +1,322 @@ + + + + + + + JsDoc Reference - jasmine.MultiReporter + + + + + + + + + + + +
    + +
    Class Index +| File Index
    +
    +

    Classes

    + +
    + +
    + +
    + +

    + + Class jasmine.MultiReporter +

    + + +

    + + + + + +
    Defined in: jasmine.js. + +

    + + + + + + + + + + + + + + + + + +
    Class Summary
    Constructor AttributesConstructor Name and Description
      + +
    +
    + + + + + + + + + + + + +
    +
    + Class Detail +
    + +
    + jasmine.MultiReporter() +
    + +
    + + +
    + + + + + + + + + + + + +
    + + + + + + + + + + + +
    +
    + + + +
    + + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT) +
    + + diff --git a/doc/symbols/jasmine.NestedResults.html b/doc/symbols/jasmine.NestedResults.html index 4246ea8..4456a16 100644 --- a/doc/symbols/jasmine.NestedResults.html +++ b/doc/symbols/jasmine.NestedResults.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: NestedResults.js. +
    Defined in: jasmine.js.

    @@ -535,7 +543,7 @@ ul.inheritsList
    Parameters:
    - {jasmine.ExpectationResult|jasmine.NestedResults} result + {jasmine.ExpectationResult|jasmine.NestedResults} result
    @@ -692,7 +700,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.QueuedFunction.html b/doc/symbols/jasmine.QueuedFunction.html index 0c5f0e8..f53996b 100644 --- a/doc/symbols/jasmine.QueuedFunction.html +++ b/doc/symbols/jasmine.QueuedFunction.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: QueuedFunction.js. +
    Defined in: jasmine.js.

    @@ -259,60 +267,6 @@ ul.inheritsList - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    Method Summary
    Method AttributesMethod Name and Description
      -
    execute() -
    -
    -
      -
    fail(e) -
    -
    -
      -
    next() -
    -
    -
      - -
    -
    - - - - @@ -340,7 +294,7 @@ ul.inheritsList
    Parameters:
    - {jasmine.Env} env + {jasmine.Env} env
    @@ -364,7 +318,7 @@ ul.inheritsList
    - {jasmine.Spec} spec + {jasmine.Spec} spec
    @@ -386,122 +340,6 @@ ul.inheritsList -
    - Method Detail -
    - - -
    - - - execute() - -
    -
    - - - -
    - - - - - - - - - - - -
    - - -
    - - - fail(e) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - e - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - next() - -
    -
    - - - -
    - - - - - - - - - - - -
    - - -
    - - - safeExecute() - -
    -
    - - - -
    - - - - - - - - - - - - - - @@ -513,7 +351,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.Reporter.html b/doc/symbols/jasmine.Reporter.html new file mode 100644 index 0000000..f3b5cff --- /dev/null +++ b/doc/symbols/jasmine.Reporter.html @@ -0,0 +1,322 @@ + + + + + + + JsDoc Reference - jasmine.Reporter + + + + + + + + + + + +
    + +
    Class Index +| File Index
    +
    +

    Classes

    + +
    + +
    + +
    + +

    + + Class jasmine.Reporter +

    + + +

    + + + + + +
    Defined in: jasmine.js. + +

    + + + + + + + + + + + + + + + + + +
    Class Summary
    Constructor AttributesConstructor Name and Description
      + +
    No-op base class for Jasmine reporters.
    +
    + + + + + + + + + + + + +
    +
    + Class Detail +
    + +
    + jasmine.Reporter() +
    + +
    + No-op base class for Jasmine reporters. + +
    + + + + + + + + + + + + +
    + + + + + + + + + + + +
    +
    + + + +
    + + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT) +
    + + diff --git a/doc/symbols/jasmine.Runner.html b/doc/symbols/jasmine.Runner.html index 4e68965..476886d 100644 --- a/doc/symbols/jasmine.Runner.html +++ b/doc/symbols/jasmine.Runner.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: Runner.js. +
    Defined in: jasmine.js.

    @@ -259,42 +267,6 @@ ul.inheritsList - - - - - - - - - - - - - - - - - - - - - - - -
    Method Summary
    Method AttributesMethod Name and Description
      - -
    -
      - -
    -
    - - - - @@ -322,7 +294,7 @@ ul.inheritsList
    Parameters:
    - {jasmine.Env} env + {jasmine.Env} env
    @@ -344,61 +316,6 @@ ul.inheritsList -
    - Method Detail -
    - - -
    - - - finishCallback() - -
    -
    - - - -
    - - - - - - - - - - - -
    - - -
    - - - getResults() - -
    -
    - - - -
    - - - - - - - - - - - - - - @@ -410,7 +327,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.Spec.html b/doc/symbols/jasmine.Spec.html index 092be9a..3d061ad 100644 --- a/doc/symbols/jasmine.Spec.html +++ b/doc/symbols/jasmine.Spec.html @@ -197,14 +197,20 @@ ul.inheritsList
  • jasmine.Env
  • +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • jasmine.Spec
  • +
  • jasmine.Spy
  • +
  • jasmine.Suite
  • jasmine.util
  • @@ -228,7 +234,7 @@ ul.inheritsList -
    Defined in: Spec.js. +
    Defined in: jasmine.js.

    @@ -247,9 +253,9 @@ ul.inheritsList  
    - jasmine.Spec(env, description, description) + jasmine.Spec(env, suite, description)
    -
    Spec
    +
    Internal representation of a Jasmine specification, or test.
    @@ -261,33 +267,6 @@ ul.inheritsList - - - - - - - - - - - - - - - - - - -
    Method Summary
    Method AttributesMethod Name and Description
      -
    expects_that(actual) -
    -
    -
    - - - - @@ -299,11 +278,11 @@ ul.inheritsList
    - jasmine.Spec(env, description, description) + jasmine.Spec(env, suite, description)
    - Spec + Internal representation of a Jasmine specification, or test.
    @@ -321,13 +300,13 @@ ul.inheritsList
    - {String} description + {jasmine.Suite} suite
    - description + {String} description
    @@ -349,47 +328,6 @@ ul.inheritsList -
    - Method Detail -
    - - -
    - - - expects_that(actual) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - actual - -
    -
    - -
    - - - - - - - - - - - @@ -401,7 +339,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Fri Jun 26 2009 08:22:36 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.Spy.html b/doc/symbols/jasmine.Spy.html index c928f68..d498a08 100644 --- a/doc/symbols/jasmine.Spy.html +++ b/doc/symbols/jasmine.Spy.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: base.js. +
    Defined in: jasmine.js.

    @@ -837,7 +845,7 @@ expect(foo.bar.callCount).toEqual(0);
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.Suite.html b/doc/symbols/jasmine.Suite.html index 22ecbbb..41cb491 100644 --- a/doc/symbols/jasmine.Suite.html +++ b/doc/symbols/jasmine.Suite.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: Suite.js. +
    Defined in: jasmine.js.

    @@ -247,7 +255,7 @@ ul.inheritsList
    jasmine.Suite(env, description, specDefinitions, parentSuite)
    -
    For storing & executing a Jasmine suite.
    +
    Internal representation of a Jasmine suite.
    @@ -259,69 +267,6 @@ ul.inheritsList - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    Method Summary
    Method AttributesMethod Name and Description
      -
    afterEach(afterEachFunction) -
    -
    -
      -
    beforeEach(beforeEachFunction) -
    -
    -
      - -
    -
      - -
    -
      - -
    -
    - - - - @@ -337,7 +282,7 @@ ul.inheritsList
    - For storing & executing a Jasmine suite. + Internal representation of a Jasmine suite.
    @@ -349,7 +294,7 @@ ul.inheritsList
    Parameters:
    - {jasmine.Env} env + {jasmine.Env} env
    @@ -389,158 +334,6 @@ ul.inheritsList -
    - Method Detail -
    - - -
    - - - afterEach(afterEachFunction) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - afterEachFunction - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - beforeEach(beforeEachFunction) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - beforeEachFunction - -
    -
    - -
    - - - - - - - - -
    - - -
    - - - finishCallback() - -
    -
    - - - -
    - - - - - - - - - - - -
    - - -
    - - - getFullName() - -
    -
    - - - -
    - - - - - - - - - - - -
    - - -
    - - - getResults() - -
    -
    - - - -
    - - - - - - - - - - - - - - @@ -552,7 +345,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.html b/doc/symbols/jasmine.html index 92cd1ed..58b2de8 100644 --- a/doc/symbols/jasmine.html +++ b/doc/symbols/jasmine.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: base.js. +
    Defined in: jasmine.js.

    @@ -285,15 +293,6 @@ ul.inheritsList - - <static>   - -
    jasmine.createSpy(name) -
    -
    - - - <static>   @@ -303,33 +302,6 @@ ul.inheritsList - - <static>   - -
    jasmine.Env() -
    -
    - - - - - <static>   - -
    jasmine.ExpectationResult(passed, message, details) -
    -
    - - - - - <static>   - -
    jasmine.FakeTimer() -
    -
    - - - <static>   @@ -358,33 +330,6 @@ Jasmine environment. - - <static>   - -
    jasmine.log(message) -
    -
    - - - - - <static>   - -
    jasmine.Matchers(env, actual, results) -
    -
    - - - - - <static>   - -
    jasmine.MessageResult(text) -
    -
    - - - <static>   @@ -403,33 +348,6 @@ Jasmine environment. - - <static>   - -
    jasmine.specFilter() -
    -
    - - - - - <static>   - -
    jasmine.StringPrettyPrinter() -
    -
    - - - - - <static>   - -
    jasmine.XmlHttpRequest() -
    -
    - - - @@ -524,42 +442,6 @@ expect(mySpy).wasCalledWith(jasmine.any(Function)); -
    - - -
    <static> - - - jasmine.createSpy(name) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - name - -
    -
    - -
    - - - - - - - -
    @@ -603,110 +485,6 @@ large in one call. -
    - - -
    <static> - - - jasmine.Env() - -
    -
    - - -
    - Defined in: Env.js. - - -
    - - - - - - - - - - - -
    - - -
    <static> - - - jasmine.ExpectationResult(passed, message, details) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - passed - -
    -
    - -
    - message - -
    -
    - -
    - details - -
    -
    - -
    - - - - - - - - -
    - - -
    <static> - - - jasmine.FakeTimer() - -
    -
    - - -
    - Defined in: mock-timeout.js. - - -
    - - - - - - - - - - -
    @@ -818,129 +596,6 @@ Jasmine environment. -
    - - -
    <static> - - - jasmine.log(message) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - message - -
    -
    - -
    - - - - - - - - -
    - - -
    <static> - - - jasmine.Matchers(env, actual, results) - -
    -
    - - -
    - Defined in: Matchers.js. - - -
    - - - - -
    -
    Parameters:
    - -
    - env - -
    -
    - -
    - actual - -
    -
    - -
    - results - -
    -
    - -
    - - - - - - - - -
    - - -
    <static> - - - jasmine.MessageResult(text) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - text - -
    -
    - -
    - - - - - - - -
    @@ -996,90 +651,6 @@ Jasmine environment.
    Base class for pretty printing for expectation results. -
    - Defined in: PrettyPrinter.js. - - -
    - - - - - - - - - - - -
    - - -
    <static> - - - jasmine.specFilter() - -
    -
    - - -
    - Defined in: Env.js. - - -
    - - - - - - - - - - - -
    - - -
    <static> - - - jasmine.StringPrettyPrinter() - -
    -
    - - -
    - Defined in: PrettyPrinter.js. - - -
    - - - - - - - - - - - -
    - - -
    <static> - - - jasmine.XmlHttpRequest() - -
    -
    - -
    @@ -1107,7 +678,7 @@ Jasmine environment.
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:05 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:18 GMT-0700 (PDT)
    diff --git a/doc/symbols/jasmine.util.html b/doc/symbols/jasmine.util.html index 10cea8e..f10d29b 100644 --- a/doc/symbols/jasmine.util.html +++ b/doc/symbols/jasmine.util.html @@ -195,12 +195,20 @@ ul.inheritsList
  • jasmine.ActionCollection
  • +
  • jasmine.Env
  • + +
  • jasmine.MultiReporter
  • +
  • jasmine.NestedResults
  • jasmine.QueuedFunction
  • +
  • jasmine.Reporter
  • +
  • jasmine.Runner
  • +
  • jasmine.Spec
  • +
  • jasmine.Spy
  • jasmine.Suite
  • @@ -226,7 +234,7 @@ ul.inheritsList -
    Defined in: util.js. +
    Defined in: jasmine.js.

    @@ -259,51 +267,6 @@ ul.inheritsList - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    Method Summary
    Method AttributesMethod Name and Description
    <static>   -
    jasmine.util.argsToArray(args) -
    -
    -
    <static>   -
    jasmine.util.formatException(e) -
    -
    -
    <static>   -
    jasmine.util.htmlEscape(str) -
    -
    -
    - - - - @@ -342,119 +305,6 @@ ul.inheritsList -
    - Method Detail -
    - - -
    <static> - - - jasmine.util.argsToArray(args) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - args - -
    -
    - -
    - - - - - - - - -
    - - -
    <static> - - - jasmine.util.formatException(e) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - e - -
    -
    - -
    - - - - - - - - -
    - - -
    <static> - - - jasmine.util.htmlEscape(str) - -
    -
    - - - -
    - - - - -
    -
    Parameters:
    - -
    - str - -
    -
    - -
    - - - - - - - - - - - @@ -466,7 +316,7 @@ ul.inheritsList
    - Documentation generated by JsDoc Toolkit 2.3.0 on Sun Jun 28 2009 13:34:06 GMT-0700 (PDT) + Documentation generated by JsDoc Toolkit 2.3.0 on Thu Jul 09 2009 21:42:19 GMT-0700 (PDT)
    diff --git a/doc/symbols/src/lib_jasmine.js.html b/doc/symbols/src/lib_jasmine.js.html new file mode 100644 index 0000000..5edd9e9 --- /dev/null +++ b/doc/symbols/src/lib_jasmine.js.html @@ -0,0 +1,1937 @@ +
      1 /**
    +  2  * Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
    +  3  * 
    +  4  * @namespace
    +  5  */
    +  6 var jasmine = {};
    +  7 
    +  8 /**
    +  9  * @private
    + 10  */
    + 11 jasmine.unimplementedMethod_ = function() {
    + 12   throw new Error("unimplemented method");
    + 13 };
    + 14 
    + 15 /**
    + 16  * Allows for bound functions to be comapred.  Internal use only.
    + 17  *
    + 18  * @ignore
    + 19  * @private
    + 20  * @param base {Object} bound 'this' for the function
    + 21  * @param name {Function} function to find
    + 22  */
    + 23 jasmine.bindOriginal_ = function(base, name) {
    + 24   var original = base[name];
    + 25   return function() {
    + 26     return original.apply(base, arguments);
    + 27   };
    + 28 };
    + 29 
    + 30 jasmine.setTimeout = jasmine.bindOriginal_(window, 'setTimeout');
    + 31 jasmine.clearTimeout = jasmine.bindOriginal_(window, 'clearTimeout');
    + 32 jasmine.setInterval = jasmine.bindOriginal_(window, 'setInterval');
    + 33 jasmine.clearInterval = jasmine.bindOriginal_(window, 'clearInterval');
    + 34 
    + 35 jasmine.MessageResult = function(text) {
    + 36   this.type = 'MessageResult';
    + 37   this.text = text;
    + 38   this.trace = new Error(); // todo: test better
    + 39 };
    + 40 
    + 41 jasmine.ExpectationResult = function(passed, message, details) {
    + 42   this.type = 'ExpectationResult';
    + 43   this.passed = passed;
    + 44   this.message = message;
    + 45   this.details = details;
    + 46   this.trace = new Error(message); // todo: test better
    + 47 };
    + 48 
    + 49 /**
    + 50  * Getter for the Jasmine environment. Ensures one gets created
    + 51  */
    + 52 jasmine.getEnv = function() {
    + 53   return jasmine.currentEnv_ = jasmine.currentEnv_ || new jasmine.Env();
    + 54 };
    + 55 
    + 56 /**
    + 57  * @ignore
    + 58  * @private
    + 59  * @param value
    + 60  * @returns {Boolean}
    + 61  */
    + 62 jasmine.isArray_ = function(value) {
    + 63   return value &&
    + 64   typeof value === 'object' &&
    + 65   typeof value.length === 'number' &&
    + 66   typeof value.splice === 'function' &&
    + 67   !(value.propertyIsEnumerable('length'));
    + 68 };
    + 69 
    + 70 /**
    + 71  * Pretty printer for expecations.  Takes any object and turns it into a human-readable string.
    + 72  *
    + 73  * @param value {Object} an object to be outputted
    + 74  * @returns {String}
    + 75  */
    + 76 jasmine.pp = function(value) {
    + 77   var stringPrettyPrinter = new jasmine.StringPrettyPrinter();
    + 78   stringPrettyPrinter.format(value);
    + 79   return stringPrettyPrinter.string;
    + 80 };
    + 81 
    + 82 /**
    + 83  * Returns true if the object is a DOM Node.
    + 84  *
    + 85  * @param {Object} obj object to check
    + 86  * @returns {Boolean}
    + 87  */
    + 88 jasmine.isDomNode = function(obj) {
    + 89   return obj['nodeType'] > 0;
    + 90 };
    + 91 
    + 92 /**
    + 93  * Returns a matchable 'generic' object of the class type.  For use in expecations of type when values don't matter.
    + 94  *
    + 95  * @example
    + 96  * // don't care about which function is passed in, as long as it's a function
    + 97  * expect(mySpy).wasCalledWith(jasmine.any(Function));
    + 98  *
    + 99  * @param {Class} clazz
    +100  * @returns matchable object of the type clazz
    +101  */
    +102 jasmine.any = function(clazz) {
    +103   return new jasmine.Matchers.Any(clazz);
    +104 };
    +105 
    +106 /**
    +107  * Jasmine Spies are test doubles that can act as stubs, spies, fakes or when used in an expecation, mocks.
    +108  *
    +109  * Spies should be created in test setup, before expectations.  They can then be checked, using the standard Jasmine
    +110  * expectation syntax. Spies can be checked if they were called or not and what the calling params were.
    +111  *
    +112  * A Spy has the following mehtod: wasCalled, callCount, mostRecentCall, and argsForCall (see docs)
    +113  * Spies are torn down at the end of every spec.
    +114  *
    +115  * Note: Do <b>not</b> call new jasmine.Spy() directly - a spy must be created using spyOn, jasmine.createSpy or jasmine.createSpyObj.
    +116  * 
    +117  * @example
    +118  * // a stub
    +119  * var myStub = jasmine.createSpy('myStub');  // can be used anywhere
    +120  *
    +121  * // spy example
    +122  * var foo = {
    +123  *   not: function(bool) { return !bool; }
    +124  * }
    +125  *
    +126  * // actual foo.not will not be called, execution stops
    +127  * spyOn(foo, 'not');
    +128 
    +129  // foo.not spied upon, execution will continue to implementation
    +130  * spyOn(foo, 'not').andCallThrough();
    +131  *
    +132  * // fake example
    +133  * var foo = {
    +134  *   not: function(bool) { return !bool; }
    +135  * }
    +136  *
    +137  * // foo.not(val) will return val
    +138  * spyOn(foo, 'not').andCallFake(function(value) {return value;});
    +139  *
    +140  * // mock example
    +141  * foo.not(7 == 7);
    +142  * expect(foo.not).wasCalled();
    +143  * expect(foo.not).wasCalledWith(true);
    +144  *
    +145  * @constructor
    +146  * @see spyOn, jasmine.createSpy, jasmine.createSpyObj
    +147  * @param {String} name
    +148  */
    +149 jasmine.Spy = function(name) {
    +150   /**
    +151    * The name of the spy, if provided.
    +152    */
    +153   this.identity = name || 'unknown';
    +154   /**
    +155    *  Is this Object a spy?
    +156    */
    +157   this.isSpy = true;
    +158   /**
    +159    * The acutal function this spy stubs.
    +160    */
    +161   this.plan = function() {};
    +162   /**
    +163    * Tracking of the most recent call to the spy.
    +164    * @example
    +165    * var mySpy = jasmine.createSpy('foo');
    +166    * mySpy(1, 2);
    +167    * mySpy.mostRecentCall.args = [1, 2];
    +168    */
    +169   this.mostRecentCall = {};
    +170 
    +171   /**
    +172    * Holds arguments for each call to the spy, indexed by call count
    +173    * @example
    +174    * var mySpy = jasmine.createSpy('foo');
    +175    * mySpy(1, 2);
    +176    * mySpy(7, 8);
    +177    * mySpy.mostRecentCall.args = [7, 8];
    +178    * mySpy.argsForCall[0] = [1, 2];
    +179    * mySpy.argsForCall[1] = [7, 8];
    +180    */
    +181   this.argsForCall = [];
    +182 };
    +183 
    +184 /**
    +185  * Tells a spy to call through to the actual implemenatation.
    +186  *
    +187  * @example
    +188  * var foo = {
    +189  *   bar: function() { // do some stuff }
    +190  * }
    +191  * 
    +192  * // defining a spy on an existing property: foo.bar
    +193  * spyOn(foo, 'bar').andCallThrough();
    +194  */
    +195 jasmine.Spy.prototype.andCallThrough = function() {
    +196   this.plan = this.originalValue;
    +197   return this;
    +198 };
    +199 
    +200 /**
    +201  * For setting the return value of a spy.
    +202  *
    +203  * @example
    +204  * // defining a spy from scratch: foo() returns 'baz'
    +205  * var foo = jasmine.createSpy('spy on foo').andReturn('baz');
    +206  *
    +207  * // defining a spy on an existing property: foo.bar() returns 'baz'
    +208  * spyOn(foo, 'bar').andReturn('baz');
    +209  *
    +210  * @param {Object} value
    +211  */
    +212 jasmine.Spy.prototype.andReturn = function(value) {
    +213   this.plan = function() {
    +214     return value;
    +215   };
    +216   return this;
    +217 };
    +218 
    +219 /**
    +220  * For throwing an exception when a spy is called.
    +221  *
    +222  * @example
    +223  * // defining a spy from scratch: foo() throws an exception w/ message 'ouch'
    +224  * var foo = jasmine.createSpy('spy on foo').andThrow('baz');
    +225  *
    +226  * // defining a spy on an existing property: foo.bar() throws an exception w/ message 'ouch'
    +227  * spyOn(foo, 'bar').andThrow('baz');
    +228  *
    +229  * @param {String} exceptionMsg
    +230  */
    +231 jasmine.Spy.prototype.andThrow = function(exceptionMsg) {
    +232   this.plan = function() {
    +233     throw exceptionMsg;
    +234   };
    +235   return this;
    +236 };
    +237 
    +238 /**
    +239  * Calls an alternate implementation when a spy is called.
    +240  *
    +241  * @example
    +242  * var baz = function() {
    +243  *   // do some stuff, return something
    +244  * }
    +245  * // defining a spy from scratch: foo() calls the function baz
    +246  * var foo = jasmine.createSpy('spy on foo').andCall(baz);
    +247  *
    +248  * // defining a spy on an existing property: foo.bar() calls an anonymnous function
    +249  * spyOn(foo, 'bar').andCall(function() { return 'baz';} );
    +250  *
    +251  * @param {Function} fakeFunc
    +252  */
    +253 jasmine.Spy.prototype.andCallFake = function(fakeFunc) {
    +254   this.plan = fakeFunc;
    +255   return this;
    +256 };
    +257 
    +258 /**
    +259  * Resets all of a spy's the tracking variables so that it can be used again.
    +260  *
    +261  * @example
    +262  * spyOn(foo, 'bar');
    +263  *
    +264  * foo.bar();
    +265  *
    +266  * expect(foo.bar.callCount).toEqual(1);
    +267  *
    +268  * foo.bar.reset();
    +269  *
    +270  * expect(foo.bar.callCount).toEqual(0);
    +271  */
    +272 jasmine.Spy.prototype.reset = function() {
    +273   this.wasCalled = false;
    +274   this.callCount = 0;
    +275   this.argsForCall = [];
    +276   this.mostRecentCall = {};
    +277 };
    +278 
    +279 jasmine.createSpy = function(name) {
    +280 
    +281   var spyObj = function() {
    +282     spyObj.wasCalled = true;
    +283     spyObj.callCount++;
    +284     var args = jasmine.util.argsToArray(arguments);
    +285     //spyObj.mostRecentCall = {
    +286     //  object: this,
    +287     //  args: args
    +288     //};
    +289     spyObj.mostRecentCall.object = this;
    +290     spyObj.mostRecentCall.args = args;
    +291     spyObj.argsForCall.push(args);
    +292     return spyObj.plan.apply(this, arguments);
    +293   };
    +294 
    +295   var spy = new jasmine.Spy(name);
    +296   
    +297   for(var prop in spy) {
    +298     spyObj[prop] = spy[prop];
    +299   }
    +300   
    +301   spyObj.reset();
    +302 
    +303   return spyObj;
    +304 };
    +305 
    +306 /**
    +307  * Creates a more complicated spy: an Object that has every property a function that is a spy.  Used for stubbing something
    +308  * large in one call.
    +309  *
    +310  * @param {String} baseName name of spy class
    +311  * @param {Array} methodNames array of names of methods to make spies
    +312  */
    +313 jasmine.createSpyObj = function(baseName, methodNames) {
    +314   var obj = {};
    +315   for (var i = 0; i < methodNames.length; i++) {
    +316     obj[methodNames[i]] = jasmine.createSpy(baseName + '.' + methodNames[i]);
    +317   }
    +318   return obj;
    +319 };
    +320 
    +321 jasmine.log = function(message) {
    +322   jasmine.getEnv().currentSpec.getResults().log(message);
    +323 };
    +324 
    +325 /**
    +326  * Function that installs a spy on an existing object's method name.  Used within a Spec to create a spy.
    +327  *
    +328  * @example
    +329  * // spy example
    +330  * var foo = {
    +331  *   not: function(bool) { return !bool; }
    +332  * }
    +333  * spyOn(foo, 'not'); // actual foo.not will not be called, execution stops
    +334  *
    +335  * @see jasmine.createSpy
    +336  * @param obj
    +337  * @param methodName
    +338  * @returns a Jasmine spy that can be chained with all spy methods
    +339  */
    +340 var spyOn = function(obj, methodName) {
    +341   return jasmine.getEnv().currentSpec.spyOn(obj, methodName);
    +342 };
    +343 
    +344 /**
    +345  * Creates a Jasmine spec that will be added to the current suite.
    +346  *
    +347  * // TODO: pending tests
    +348  *
    +349  * @example
    +350  * it('should be true', function() {
    +351  *   expect(true).toEqual(true);
    +352  * });
    +353  *
    +354  * @param {String} desc description of this specification
    +355  * @param {Function} func defines the preconditions and expectations of the spec
    +356  */
    +357 var it = function(desc, func) {
    +358   return jasmine.getEnv().it(desc, func);
    +359 };
    +360 
    +361 /**
    +362  * Creates a <em>disabled</em> Jasmine spec.
    +363  *
    +364  * A convenience method that allows existing specs to be disabled temporarily during development.
    +365  *
    +366  * @param {String} desc description of this specification
    +367  * @param {Function} func defines the preconditions and expectations of the spec
    +368  */
    +369 var xit = function(desc, func) {
    +370   return jasmine.getEnv().xit(desc, func);
    +371 };
    +372 
    +373 /**
    +374  * Starts a chain for a Jasmine expectation.
    +375  *
    +376  * It is passed an Object that is the actual value and should chain to one of the many
    +377  * jasmine.Matchers functions.
    +378  *
    +379  * @param {Object} actual Actual value to test against and expected value
    +380  */
    +381 var expect = function(actual) {
    +382   return jasmine.getEnv().currentSpec.expect(actual);
    +383 };
    +384 
    +385 /**
    +386  * Defines part of a jasmine spec.  Used in cominbination with waits or waitsFor in asynchrnous specs.
    +387  *
    +388  * @param {Function} func Function that defines part of a jasmine spec.
    +389  */
    +390 var runs = function(func) {
    +391   jasmine.getEnv().currentSpec.runs(func);
    +392 };
    +393 
    +394 /**
    +395  * Waits for a timeout before moving to the next runs()-defined block.
    +396  * @param {Number} timeout
    +397  */
    +398 var waits = function(timeout) {
    +399   jasmine.getEnv().currentSpec.waits(timeout);
    +400 };
    +401 
    +402 /**
    +403  * Waits for the latchFunction to return true before proceeding to the next runs()-defined block.
    +404  *  
    +405  * @param {Number} timeout
    +406  * @param {Function} latchFunction
    +407  * @param {String} message
    +408  */
    +409 var waitsFor = function(timeout, latchFunction, message) {
    +410   jasmine.getEnv().currentSpec.waitsFor(timeout, latchFunction, message);
    +411 };
    +412 
    +413 /**
    +414  * A function that is called before each spec in a suite.
    +415  *
    +416  * Used for spec setup, including validating assumptions.
    +417  *
    +418  * @param {Function} beforeEachFunction
    +419  */
    +420 var beforeEach = function(beforeEachFunction) {
    +421   jasmine.getEnv().beforeEach(beforeEachFunction);
    +422 };
    +423 
    +424 /**
    +425  * A function that is called after each spec in a suite.
    +426  *
    +427  * Used for restoring any state that is hijacked during spec execution.
    +428  *
    +429  * @param {Function} afterEachFunction
    +430  */
    +431 var afterEach = function(afterEachFunction) {
    +432   jasmine.getEnv().afterEach(afterEachFunction);
    +433 };
    +434 
    +435 /**
    +436  * Defines a suite of specifications.
    +437  *
    +438  * Stores the description and all defined specs in the Jasmine environment as one suite of specs. Variables declared
    +439  * are accessible by calls to beforeEach, it, and afterEach. Describe blocks can be nested, allowing for specialization
    +440  * of setup in some tests.
    +441  *
    +442  * @example
    +443  * // TODO: a simple suite
    +444  *
    +445  * // TODO: a simple suite with a nested describe block
    +446  *
    +447  * @param {String} description A string, usually the class under test.
    +448  * @param {Function} specDefinitions function that defines several specs.
    +449  */
    +450 var describe = function(description, specDefinitions) {
    +451   return jasmine.getEnv().describe(description, specDefinitions);
    +452 };
    +453 
    +454 /**
    +455  * Disables a suite of specifications.  Used to disable some suites in a file, or files, temporarily during development.
    +456  *
    +457  * @param {String} description A string, usually the class under test.
    +458  * @param {Function} specDefinitions function that defines several specs.
    +459  */
    +460 var xdescribe = function(description, specDefinitions) {
    +461   return jasmine.getEnv().xdescribe(description, specDefinitions);
    +462 };
    +463 
    +464 
    +465 jasmine.XmlHttpRequest = XMLHttpRequest;
    +466 
    +467 // Provide the XMLHttpRequest class for IE 5.x-6.x:
    +468 if (typeof XMLHttpRequest == "undefined") jasmine.XmlHttpRequest = function() {
    +469   try {
    +470     return new ActiveXObject("Msxml2.XMLHTTP.6.0");
    +471   } catch(e) {
    +472   }
    +473   try {
    +474     return new ActiveXObject("Msxml2.XMLHTTP.3.0");
    +475   } catch(e) {
    +476   }
    +477   try {
    +478     return new ActiveXObject("Msxml2.XMLHTTP");
    +479   } catch(e) {
    +480   }
    +481   try {
    +482     return new ActiveXObject("Microsoft.XMLHTTP");
    +483   } catch(e) {
    +484   }
    +485   throw new Error("This browser does not support XMLHttpRequest.");
    +486 };
    +487 
    +488 /**
    +489  * Adds suite files to an HTML document so that they are executed, thus adding them to the current
    +490  * Jasmine environment.
    +491  *
    +492  * @param {String} url path to the file to include
    +493  * @param {Boolean} opt_global
    +494  */
    +495 jasmine.include = function(url, opt_global) {
    +496   if (opt_global) {
    +497     document.write('<script type="text/javascript" src="' + url + '"></' + 'script>');
    +498   } else {
    +499     var xhr;
    +500     try {
    +501       xhr = new jasmine.XmlHttpRequest();
    +502       xhr.open("GET", url, false);
    +503       xhr.send(null);
    +504     } catch(e) {
    +505       throw new Error("couldn't fetch " + url + ": " + e);
    +506     }
    +507 
    +508     return eval(xhr.responseText);
    +509   }
    +510 };
    +511 /**
    +512  * @namespace
    +513  */
    +514 jasmine.util = {};
    +515 
    +516 /**
    +517  * Declare that a child class inherite it's prototype from the parent class.
    +518  *
    +519  * @private
    +520  * @param {Function} childClass
    +521  * @param {Function} parentClass
    +522  */
    +523 jasmine.util.inherit = function(childClass, parentClass) {
    +524   var subclass = function() {
    +525   };
    +526   subclass.prototype = parentClass.prototype;
    +527   childClass.prototype = new subclass;
    +528 };
    +529 
    +530 jasmine.util.formatException = function(e) {
    +531   var lineNumber;
    +532   if (e.line) {
    +533     lineNumber = e.line;
    +534   }
    +535   else if (e.lineNumber) {
    +536     lineNumber = e.lineNumber;
    +537   }
    +538 
    +539   var file;
    +540 
    +541   if (e.sourceURL) {
    +542     file = e.sourceURL;
    +543   }
    +544   else if (e.fileName) {
    +545     file = e.fileName;
    +546   }
    +547 
    +548   var message = (e.name && e.message) ? (e.name + ': ' + e.message) : e.toString();
    +549 
    +550   if (file && lineNumber) {
    +551     message += ' in ' + file + ' (line ' + lineNumber + ')';
    +552   }
    +553 
    +554   return message;
    +555 };
    +556 
    +557 jasmine.util.htmlEscape = function(str) {
    +558   if (!str) return str;
    +559   return str.replace(/&/g, '&')
    +560     .replace(/</g, '<')
    +561     .replace(/>/g, '>');
    +562 };
    +563 
    +564 jasmine.util.argsToArray = function(args) {
    +565   var arrayOfArgs = [];
    +566   for (var i = 0; i < args.length; i++) arrayOfArgs.push(args[i]);
    +567   return arrayOfArgs;
    +568 };
    +569 
    +570 /**
    +571  * Environment for Jasmine
    +572  *
    +573  * @constructor
    +574  */
    +575 jasmine.Env = function() {
    +576   this.currentSpec = null;
    +577   this.currentSuite = null;
    +578   this.currentRunner = new jasmine.Runner(this);
    +579   this.currentlyRunningTests = false;
    +580 
    +581   this.reporter = new jasmine.MultiReporter();
    +582 
    +583   this.updateInterval = 0;
    +584   this.lastUpdate = 0;
    +585   this.specFilter = function() {
    +586     return true;
    +587   };
    +588 
    +589   this.nextSpecId_ = 0;
    +590   this.equalityTesters_ = [];
    +591 };
    +592 
    +593 
    +594 jasmine.Env.prototype.setTimeout = jasmine.setTimeout;
    +595 jasmine.Env.prototype.clearTimeout = jasmine.clearTimeout;
    +596 jasmine.Env.prototype.setInterval = jasmine.setInterval;
    +597 jasmine.Env.prototype.clearInterval = jasmine.clearInterval;
    +598 
    +599 /**
    +600  * Register a reporter to receive status updates from Jasmine.
    +601  * @param {jasmine.Reporter} reporter An object which will receive status updates.
    +602  */
    +603 jasmine.Env.prototype.addReporter = function(reporter) {
    +604   this.reporter.addReporter(reporter);
    +605 };
    +606 
    +607 jasmine.Env.prototype.execute = function() {
    +608   this.currentRunner.execute();
    +609 };
    +610 
    +611 jasmine.Env.prototype.describe = function(description, specDefinitions) {
    +612   var suite = new jasmine.Suite(this, description, specDefinitions, this.currentSuite);
    +613 
    +614   var parentSuite = this.currentSuite;
    +615   if (parentSuite) {
    +616     parentSuite.specs.push(suite);
    +617   } else {
    +618     this.currentRunner.suites.push(suite);
    +619   }
    +620 
    +621   this.currentSuite = suite;
    +622 
    +623   specDefinitions.call(suite);
    +624 
    +625   this.currentSuite = parentSuite;
    +626 
    +627   return suite;
    +628 };
    +629 
    +630 jasmine.Env.prototype.beforeEach = function(beforeEachFunction) {
    +631   this.currentSuite.beforeEach(beforeEachFunction);
    +632 };
    +633 
    +634 jasmine.Env.prototype.afterEach = function(afterEachFunction) {
    +635   this.currentSuite.afterEach(afterEachFunction);
    +636 };
    +637 
    +638 jasmine.Env.prototype.xdescribe = function(desc, specDefinitions) {
    +639   return {
    +640     execute: function() {
    +641     }
    +642   };
    +643 };
    +644 
    +645 jasmine.Env.prototype.it = function(description, func) {
    +646   var spec = new jasmine.Spec(this, this.currentSuite, description);
    +647   this.currentSuite.specs.push(spec);
    +648   this.currentSpec = spec;
    +649 
    +650   if (func) {
    +651     spec.addToQueue(func);
    +652   }
    +653 
    +654   return spec;
    +655 };
    +656 
    +657 jasmine.Env.prototype.xit = function(desc, func) {
    +658   return {
    +659     id: this.nextSpecId_++,
    +660     runs: function() {
    +661     }
    +662   };
    +663 };
    +664 
    +665 jasmine.Env.prototype.compareObjects_ = function(a, b, mismatchKeys, mismatchValues) {
    +666   if (a.__Jasmine_been_here_before__ === b && b.__Jasmine_been_here_before__ === a) {
    +667     return true;
    +668   }
    +669 
    +670   a.__Jasmine_been_here_before__ = b;
    +671   b.__Jasmine_been_here_before__ = a;
    +672 
    +673   var hasKey = function(obj, keyName) {
    +674     return obj != null && obj[keyName] !== undefined;
    +675   };
    +676 
    +677   for (var property in b) {
    +678     if (!hasKey(a, property) && hasKey(b, property)) {
    +679       mismatchKeys.push("expected has key '" + property + "', but missing from <b>actual</b>.");
    +680     }
    +681   }
    +682   for (property in a) {
    +683     if (!hasKey(b, property) && hasKey(a, property)) {
    +684       mismatchKeys.push("<b>expected</b> missing key '" + property + "', but present in actual.");
    +685     }
    +686   }
    +687   for (property in b) {
    +688     if (property == '__Jasmine_been_here_before__') continue;
    +689     if (!this.equals_(a[property], b[property], mismatchKeys, mismatchValues)) {
    +690       mismatchValues.push("'" + property + "' was<br /><br />'" + (b[property] ? jasmine.util.htmlEscape(b[property].toString()) : b[property]) + "'<br /><br />in expected, but was<br /><br />'" + (a[property] ? jasmine.util.htmlEscape(a[property].toString()) : a[property]) + "'<br /><br />in actual.<br />");
    +691     }
    +692   }
    +693 
    +694   if (jasmine.isArray_(a) && jasmine.isArray_(b) && a.length != b.length) {
    +695     mismatchValues.push("arrays were not the same length");
    +696   }
    +697 
    +698   delete a.__Jasmine_been_here_before__;
    +699   delete b.__Jasmine_been_here_before__;
    +700   return (mismatchKeys.length == 0 && mismatchValues.length == 0);
    +701 };
    +702 
    +703 jasmine.Env.prototype.equals_ = function(a, b, mismatchKeys, mismatchValues) {
    +704   mismatchKeys = mismatchKeys || [];
    +705   mismatchValues = mismatchValues || [];
    +706 
    +707   if (a === b) return true;
    +708 
    +709   if (a === undefined || a === null || b === undefined || b === null) {
    +710     return (a == undefined && b == undefined);
    +711   }
    +712 
    +713   if (jasmine.isDomNode(a) && jasmine.isDomNode(b)) {
    +714     return a === b;
    +715   }
    +716 
    +717   if (a instanceof Date && b instanceof Date) {
    +718     return a.getTime() == b.getTime();
    +719   }
    +720 
    +721   if (a instanceof jasmine.Matchers.Any) {
    +722     return a.matches(b);
    +723   }
    +724 
    +725   if (b instanceof jasmine.Matchers.Any) {
    +726     return b.matches(a);
    +727   }
    +728 
    +729   if (typeof a === "object" && typeof b === "object") {
    +730     return this.compareObjects_(a, b, mismatchKeys, mismatchValues);
    +731   }
    +732 
    +733   for (var i = 0; i < this.equalityTesters_.length; i++) {
    +734     var equalityTester = this.equalityTesters_[i];
    +735     var result = equalityTester(a, b, this, mismatchKeys, mismatchValues);
    +736     if (result !== undefined) return result;
    +737   }
    +738 
    +739   //Straight check
    +740   return (a === b);
    +741 };
    +742 
    +743 jasmine.Env.prototype.contains_ = function(haystack, needle) {
    +744   if (jasmine.isArray_(haystack)) {
    +745     for (var i = 0; i < haystack.length; i++) {
    +746       if (this.equals_(haystack[i], needle)) return true;
    +747     }
    +748     return false;
    +749   }
    +750   return haystack.indexOf(needle) >= 0;
    +751 };
    +752 
    +753 jasmine.Env.prototype.addEqualityTester = function(equalityTester) {
    +754   this.equalityTesters_.push(equalityTester);
    +755 };
    +756 /**
    +757  * base for Runner & Suite: allows for a queue of functions to get executed, allowing for
    +758  *   any one action to complete, including asynchronous calls, before going to the next
    +759  *   action.
    +760  *
    +761  * @constructor
    +762  * @param {jasmine.Env} env
    +763  */
    +764 jasmine.ActionCollection = function(env) {
    +765   this.env = env;
    +766   this.actions = [];
    +767   this.index = 0;
    +768   this.finished = false;
    +769 };
    +770 
    +771 /**
    +772  * Marks the collection as done & calls the finish callback, if there is one
    +773  */
    +774 jasmine.ActionCollection.prototype.finish = function() {
    +775   if (this.finishCallback) {
    +776     this.finishCallback();
    +777   }
    +778   this.finished = true;
    +779 };
    +780 
    +781 /**
    +782  * Starts executing the queue of functions/actions.
    +783  */
    +784 jasmine.ActionCollection.prototype.execute = function() {
    +785   if (this.actions.length > 0) {
    +786     this.next();
    +787   }
    +788 };
    +789 
    +790 /**
    +791  * Gets the current action.
    +792  */
    +793 jasmine.ActionCollection.prototype.getCurrentAction = function() {
    +794   return this.actions[this.index];
    +795 };
    +796 
    +797 /**
    +798  * Executes the next queued function/action. If there are no more in the queue, calls #finish.
    +799  */
    +800 jasmine.ActionCollection.prototype.next = function() {
    +801   if (this.index >= this.actions.length) {
    +802     this.finish();
    +803     return;
    +804   }
    +805 
    +806   var currentAction = this.getCurrentAction();
    +807 
    +808   currentAction.execute(this);
    +809 
    +810   if (currentAction.afterCallbacks) {
    +811     for (var i = 0; i < currentAction.afterCallbacks.length; i++) {
    +812       try {
    +813         currentAction.afterCallbacks[i]();
    +814       } catch (e) {
    +815         alert(e);
    +816       }
    +817     }
    +818   }
    +819 
    +820   this.waitForDone(currentAction);
    +821 };
    +822 
    +823 jasmine.ActionCollection.prototype.waitForDone = function(action) {
    +824   var self = this;
    +825   var afterExecute = function afterExecute() {
    +826     self.index++;
    +827     self.next();
    +828   };
    +829 
    +830   if (action.finished) {
    +831     var now = new Date().getTime();
    +832     if (this.env.updateInterval && now - this.env.lastUpdate > this.env.updateInterval) {
    +833       this.env.lastUpdate = now;
    +834       this.env.setTimeout(afterExecute, 0);
    +835     } else {
    +836       afterExecute();
    +837     }
    +838     return;
    +839   }
    +840 
    +841   var id = this.env.setInterval(function() {
    +842     if (action.finished) {
    +843       self.env.clearInterval(id);
    +844       afterExecute();
    +845     }
    +846   }, 150);
    +847 };
    +848 /** No-op base class for Jasmine reporters.
    +849  *
    +850  * @constructor
    +851  */
    +852 jasmine.Reporter = function() {
    +853 };
    +854 
    +855 //noinspection JSUnusedLocalSymbols
    +856 jasmine.Reporter.prototype.reportRunnerStarting = function(runner) {
    +857 };
    +858 
    +859 //noinspection JSUnusedLocalSymbols
    +860 jasmine.Reporter.prototype.reportRunnerResults = function(runner) {
    +861 };
    +862 
    +863 //noinspection JSUnusedLocalSymbols
    +864 jasmine.Reporter.prototype.reportSuiteResults = function(suite) {
    +865 };
    +866 
    +867 //noinspection JSUnusedLocalSymbols
    +868 jasmine.Reporter.prototype.reportSpecResults = function(spec) {
    +869 };
    +870 
    +871 //noinspection JSUnusedLocalSymbols
    +872 jasmine.Reporter.prototype.log = function (str) {
    +873 };
    +874 
    +875 jasmine.Matchers = function(env, actual, results) {
    +876   this.env = env;
    +877   this.actual = actual;
    +878   this.passing_message = 'Passed.';
    +879   this.results = results || new jasmine.NestedResults();
    +880 };
    +881 
    +882 jasmine.Matchers.pp = function(str) {
    +883   return jasmine.util.htmlEscape(jasmine.pp(str));
    +884 };
    +885 
    +886 jasmine.Matchers.prototype.getResults = function() {
    +887   return this.results;
    +888 };
    +889 
    +890 jasmine.Matchers.prototype.report = function(result, failing_message, details) {
    +891   this.results.addResult(new jasmine.ExpectationResult(result, result ? this.passing_message : failing_message, details));
    +892   return result;
    +893 };
    +894 
    +895 /**
    +896  * Matcher that compares the actual to the expected using ===.
    +897  *
    +898  * @param expected
    +899  */
    +900 jasmine.Matchers.prototype.toBe = function(expected) {
    +901   return this.report(this.actual === expected, 'Expected<br /><br />' + jasmine.Matchers.pp(expected)
    +902     + '<br /><br />to be the same object as<br /><br />' + jasmine.Matchers.pp(this.actual)
    +903     + '<br />');
    +904 };
    +905 
    +906 /**
    +907  * Matcher that compares the actual to the expected using !==
    +908  * @param expected
    +909  */
    +910 jasmine.Matchers.prototype.toNotBe = function(expected) {
    +911   return this.report(this.actual !== expected, 'Expected<br /><br />' + jasmine.Matchers.pp(expected)
    +912     + '<br /><br />to be a different object from actual, but they were the same.');
    +913 };
    +914 
    +915 /**
    +916  * Matcher that compares the actual to the expected using common sense equality. Handles Objects, Arrays, etc.
    +917  *
    +918  * @param expected
    +919  */
    +920 jasmine.Matchers.prototype.toEqual = function(expected) {
    +921   var mismatchKeys = [];
    +922   var mismatchValues = [];
    +923 
    +924   var formatMismatches = function(name, array) {
    +925     if (array.length == 0) return '';
    +926     var errorOutput = '<br /><br />Different ' + name + ':<br />';
    +927     for (var i = 0; i < array.length; i++) {
    +928       errorOutput += array[i] + '<br />';
    +929     }
    +930     return errorOutput;
    +931   };
    +932 
    +933   return this.report(this.env.equals_(this.actual, expected, mismatchKeys, mismatchValues),
    +934     'Expected<br /><br />' + jasmine.Matchers.pp(expected)
    +935       + '<br /><br />but got<br /><br />' + jasmine.Matchers.pp(this.actual)
    +936       + '<br />'
    +937       + formatMismatches('Keys', mismatchKeys)
    +938       + formatMismatches('Values', mismatchValues), {
    +939     matcherName: 'toEqual', expected: expected, actual: this.actual
    +940   });
    +941 };
    +942 /** @deprecated */
    +943 jasmine.Matchers.prototype.should_equal = jasmine.Matchers.prototype.toEqual;
    +944 
    +945 /**
    +946  * Matcher that compares the actual to the expected using the ! of jasmine.Matchers.toEqual
    +947  * @param expected
    +948  */
    +949 jasmine.Matchers.prototype.toNotEqual = function(expected) {
    +950   return this.report(!this.env.equals_(this.actual, expected),
    +951     'Expected ' + jasmine.Matchers.pp(expected) + ' to not equal ' + jasmine.Matchers.pp(this.actual) + ', but it does.');
    +952 };
    +953 /** @deprecated */
    +954 jasmine.Matchers.prototype.should_not_equal = jasmine.Matchers.prototype.toNotEqual;
    +955 
    +956 /**
    +957  * Matcher that compares the actual to the expected using a regular expression.  Constructs a RegExp, so takes
    +958  * a pattern or a String.
    +959  *
    +960  * @param reg_exp
    +961  */
    +962 jasmine.Matchers.prototype.toMatch = function(reg_exp) {
    +963   return this.report((new RegExp(reg_exp).test(this.actual)),
    +964     'Expected ' + jasmine.Matchers.pp(this.actual) + ' to match ' + reg_exp + '.');
    +965 };
    +966 /** @deprecated */
    +967 jasmine.Matchers.prototype.should_match = jasmine.Matchers.prototype.toMatch;
    +968 
    +969 /**
    +970  * Matcher that compares the actual to the expected using the boolean inverse of jasmine.Matchers.toMatch
    +971  * @param reg_exp
    +972  */
    +973 jasmine.Matchers.prototype.toNotMatch = function(reg_exp) {
    +974   return this.report((!new RegExp(reg_exp).test(this.actual)),
    +975     'Expected ' + jasmine.Matchers.pp(this.actual) + ' to not match ' + reg_exp + '.');
    +976 };
    +977 /** @deprecated */
    +978 jasmine.Matchers.prototype.should_not_match = jasmine.Matchers.prototype.toNotMatch;
    +979 
    +980 /**
    +981  * Matcher that compares the acutal to undefined.
    +982  */
    +983 jasmine.Matchers.prototype.toBeDefined = function() {
    +984   return this.report((this.actual !== undefined),
    +985     'Expected a value to be defined but it was undefined.');
    +986 };
    +987 /** @deprecated */
    +988 jasmine.Matchers.prototype.should_be_defined = jasmine.Matchers.prototype.toBeDefined;
    +989 
    +990 /**
    +991  * Matcher that compares the actual to null.
    +992  *
    +993  */
    +994 jasmine.Matchers.prototype.toBeNull = function() {
    +995   return this.report((this.actual === null),
    +996     'Expected a value to be null but it was ' + jasmine.Matchers.pp(this.actual) + '.');
    +997 };
    +998 /** @deprecated */
    +999 jasmine.Matchers.prototype.should_be_null = jasmine.Matchers.prototype.toBeNull;
    +1000 
    +1001 /**
    +1002  * Matcher that boolean not-nots the actual.
    +1003  */
    +1004 jasmine.Matchers.prototype.toBeTruthy = function() {
    +1005   return this.report(!!this.actual,
    +1006     'Expected a value to be truthy but it was ' + jasmine.Matchers.pp(this.actual) + '.');
    +1007 };
    +1008 /** @deprecated */
    +1009 jasmine.Matchers.prototype.should_be_truthy = jasmine.Matchers.prototype.toBeTruthy;
    +1010 
    +1011 /**
    +1012  * Matcher that boolean nots the actual.
    +1013  */
    +1014 jasmine.Matchers.prototype.toBeFalsy = function() {
    +1015   return this.report(!this.actual,
    +1016     'Expected a value to be falsy but it was ' + jasmine.Matchers.pp(this.actual) + '.');
    +1017 };
    +1018 /** @deprecated */
    +1019 jasmine.Matchers.prototype.should_be_falsy = jasmine.Matchers.prototype.toBeFalsy;
    +1020 
    +1021 /**
    +1022  * Matcher that checks to see if the acutal, a Jasmine spy, was called.
    +1023  */
    +1024 jasmine.Matchers.prototype.wasCalled = function() {
    +1025   if (!this.actual || !this.actual.isSpy) {
    +1026     return this.report(false, 'Expected a spy, but got ' + jasmine.Matchers.pp(this.actual) + '.');
    +1027   }
    +1028   if (arguments.length > 0) {
    +1029     return this.report(false, 'wasCalled matcher does not take arguments');
    +1030   }
    +1031   return this.report((this.actual.wasCalled),
    +1032     'Expected spy "' + this.actual.identity + '" to have been called, but it was not.');
    +1033 };
    +1034 /** @deprecated */
    +1035 jasmine.Matchers.prototype.was_called = jasmine.Matchers.prototype.wasCalled;
    +1036 
    +1037 /**
    +1038  * Matcher that checks to see if the acutal, a Jasmine spy, was not called.
    +1039  */
    +1040 jasmine.Matchers.prototype.wasNotCalled = function() {
    +1041   if (!this.actual || !this.actual.isSpy) {
    +1042     return this.report(false, 'Expected a spy, but got ' + jasmine.Matchers.pp(this.actual) + '.');
    +1043   }
    +1044   return this.report((!this.actual.wasCalled),
    +1045     'Expected spy "' + this.actual.identity + '" to not have been called, but it was.');
    +1046 };
    +1047 /** @deprecated */
    +1048 jasmine.Matchers.prototype.was_not_called = jasmine.Matchers.prototype.wasNotCalled;
    +1049 
    +1050 /**
    +1051  * Matcher that checks to see if the acutal, a Jasmine spy, was called with a set of parameters.
    +1052  *
    +1053  * @example
    +1054  *
    +1055  */
    +1056 jasmine.Matchers.prototype.wasCalledWith = function() {
    +1057   if (!this.actual || !this.actual.isSpy) {
    +1058     return this.report(false, 'Expected a spy, but got ' + jasmine.Matchers.pp(this.actual) + '.', {
    +1059       matcherName: 'wasCalledWith'
    +1060     });
    +1061   }
    +1062 
    +1063   var args = jasmine.util.argsToArray(arguments);
    +1064 
    +1065   return this.report(this.env.contains_(this.actual.argsForCall, args),
    +1066     'Expected ' + jasmine.Matchers.pp(this.actual.argsForCall) + ' to contain ' + jasmine.Matchers.pp(args) + ', but it does not.', {
    +1067     matcherName: 'wasCalledWith', expected: args, actual: this.actual.argsForCall
    +1068   });
    +1069 };
    +1070 
    +1071 /**
    +1072  * Matcher that checks that the expected item is an element in the actual Array.
    +1073  *
    +1074  * @param {Object} item
    +1075  */
    +1076 jasmine.Matchers.prototype.toContain = function(item) {
    +1077   return this.report(this.env.contains_(this.actual, item),
    +1078     'Expected ' + jasmine.Matchers.pp(this.actual) + ' to contain ' + jasmine.Matchers.pp(item) + ', but it does not.', {
    +1079     matcherName: 'toContain', expected: item, actual: this.actual
    +1080   });
    +1081 };
    +1082 
    +1083 /**
    +1084  * Matcher that checks that the expected item is NOT an element in the actual Array.
    +1085  *
    +1086  * @param {Object} item
    +1087  */
    +1088 jasmine.Matchers.prototype.toNotContain = function(item) {
    +1089   return this.report(!this.env.contains_(this.actual, item),
    +1090     'Expected ' + jasmine.Matchers.pp(this.actual) + ' not to contain ' + jasmine.Matchers.pp(item) + ', but it does.');
    +1091 };
    +1092 
    +1093 /**
    +1094  * Matcher that checks that the expected exception was thrown by the actual.
    +1095  *
    +1096  * @param {String} expectedException
    +1097  */
    +1098 jasmine.Matchers.prototype.toThrow = function(expectedException) {
    +1099   var exception = null;
    +1100   try {
    +1101     this.actual();
    +1102   } catch (e) {
    +1103     exception = e;
    +1104   }
    +1105   if (expectedException !== undefined) {
    +1106     if (exception == null) {
    +1107       return this.report(false, "Expected function to throw " + jasmine.Matchers.pp(expectedException) + ", but it did not.");
    +1108     }
    +1109     return this.report(
    +1110       this.env.equals_(
    +1111         exception.message || exception,
    +1112         expectedException.message || expectedException),
    +1113       "Expected function to throw " + jasmine.Matchers.pp(expectedException) + ", but it threw " + jasmine.Matchers.pp(exception) + ".");
    +1114   } else {
    +1115     return this.report(exception != null, "Expected function to throw an exception, but it did not.");
    +1116   }
    +1117 };
    +1118 
    +1119 jasmine.Matchers.Any = function(expectedClass) {
    +1120   this.expectedClass = expectedClass;
    +1121 };
    +1122 
    +1123 jasmine.Matchers.Any.prototype.matches = function(other) {
    +1124   if (this.expectedClass == String) {
    +1125     return typeof other == 'string' || other instanceof String;
    +1126   }
    +1127 
    +1128   if (this.expectedClass == Number) {
    +1129     return typeof other == 'number' || other instanceof Number;
    +1130   }
    +1131 
    +1132   if (this.expectedClass == Function) {
    +1133     return typeof other == 'function' || other instanceof Function;
    +1134   }
    +1135 
    +1136   if (this.expectedClass == Object) {
    +1137     return typeof other == 'object';
    +1138   }
    +1139 
    +1140   return other instanceof this.expectedClass;
    +1141 };
    +1142 
    +1143 jasmine.Matchers.Any.prototype.toString = function() {
    +1144   return '<jasmine.any(' + this.expectedClass + ')>';
    +1145 };
    +1146 
    +1147 // Mock setTimeout, clearTimeout
    +1148 // Contributed by Pivotal Computer Systems, www.pivotalsf.com
    +1149 
    +1150 jasmine.FakeTimer = function() {
    +1151   this.reset();
    +1152 
    +1153   var self = this;
    +1154   self.setTimeout = function(funcToCall, millis) {
    +1155     self.timeoutsMade++;
    +1156     self.scheduleFunction(self.timeoutsMade, funcToCall, millis, false);
    +1157     return self.timeoutsMade;
    +1158   };
    +1159 
    +1160   self.setInterval = function(funcToCall, millis) {
    +1161     self.timeoutsMade++;
    +1162     self.scheduleFunction(self.timeoutsMade, funcToCall, millis, true);
    +1163     return self.timeoutsMade;
    +1164   };
    +1165 
    +1166   self.clearTimeout = function(timeoutKey) {
    +1167     self.scheduledFunctions[timeoutKey] = undefined;
    +1168   };
    +1169 
    +1170   self.clearInterval = function(timeoutKey) {
    +1171     self.scheduledFunctions[timeoutKey] = undefined;
    +1172   };
    +1173 
    +1174 };
    +1175 
    +1176 jasmine.FakeTimer.prototype.reset = function() {
    +1177   this.timeoutsMade = 0;
    +1178   this.scheduledFunctions = {};
    +1179   this.nowMillis = 0;
    +1180 };
    +1181 
    +1182 jasmine.FakeTimer.prototype.tick = function(millis) {
    +1183   var oldMillis = this.nowMillis;
    +1184   var newMillis = oldMillis + millis;
    +1185   this.runFunctionsWithinRange(oldMillis, newMillis);
    +1186   this.nowMillis = newMillis;
    +1187 };
    +1188 
    +1189 jasmine.FakeTimer.prototype.runFunctionsWithinRange = function(oldMillis, nowMillis) {
    +1190   var scheduledFunc;
    +1191   var funcsToRun = [];
    +1192   for (var timeoutKey in this.scheduledFunctions) {
    +1193     scheduledFunc = this.scheduledFunctions[timeoutKey];
    +1194     if (scheduledFunc != undefined &&
    +1195         scheduledFunc.runAtMillis >= oldMillis &&
    +1196         scheduledFunc.runAtMillis <= nowMillis) {
    +1197       funcsToRun.push(scheduledFunc);
    +1198       this.scheduledFunctions[timeoutKey] = undefined;
    +1199     }
    +1200   }
    +1201 
    +1202   if (funcsToRun.length > 0) {
    +1203     funcsToRun.sort(function(a, b) {
    +1204       return a.runAtMillis - b.runAtMillis;
    +1205     });
    +1206     for (var i = 0; i < funcsToRun.length; ++i) {
    +1207       try {
    +1208         var funcToRun = funcsToRun[i];
    +1209         this.nowMillis = funcToRun.runAtMillis;
    +1210         funcToRun.funcToCall();
    +1211         if (funcToRun.recurring) {
    +1212           this.scheduleFunction(funcToRun.timeoutKey,
    +1213             funcToRun.funcToCall,
    +1214             funcToRun.millis,
    +1215             true);
    +1216         }
    +1217       } catch(e) {
    +1218       }
    +1219     }
    +1220     this.runFunctionsWithinRange(oldMillis, nowMillis);
    +1221   }
    +1222 };
    +1223 
    +1224 jasmine.FakeTimer.prototype.scheduleFunction = function(timeoutKey, funcToCall, millis, recurring) {
    +1225   this.scheduledFunctions[timeoutKey] = {
    +1226     runAtMillis: this.nowMillis + millis,
    +1227     funcToCall: funcToCall,
    +1228     recurring: recurring,
    +1229     timeoutKey: timeoutKey,
    +1230     millis: millis
    +1231   };
    +1232 };
    +1233 
    +1234 
    +1235 jasmine.Clock = {
    +1236   defaultFakeTimer: new jasmine.FakeTimer(),
    +1237 
    +1238   reset: function() {
    +1239     jasmine.Clock.assertInstalled();
    +1240     jasmine.Clock.defaultFakeTimer.reset();
    +1241   },
    +1242 
    +1243   tick: function(millis) {
    +1244     jasmine.Clock.assertInstalled();
    +1245     jasmine.Clock.defaultFakeTimer.tick(millis);
    +1246   },
    +1247 
    +1248   runFunctionsWithinRange: function(oldMillis, nowMillis) {
    +1249     jasmine.Clock.defaultFakeTimer.runFunctionsWithinRange(oldMillis, nowMillis);
    +1250   },
    +1251 
    +1252   scheduleFunction: function(timeoutKey, funcToCall, millis, recurring) {
    +1253     jasmine.Clock.defaultFakeTimer.scheduleFunction(timeoutKey, funcToCall, millis, recurring);
    +1254   },
    +1255 
    +1256   useMock: function() {
    +1257     var spec = jasmine.getEnv().currentSpec;
    +1258     spec.after(jasmine.Clock.uninstallMock);
    +1259 
    +1260     jasmine.Clock.installMock();
    +1261   },
    +1262 
    +1263   installMock: function() {
    +1264     jasmine.Clock.installed = jasmine.Clock.defaultFakeTimer;
    +1265   },
    +1266 
    +1267   uninstallMock: function() {
    +1268     jasmine.Clock.assertInstalled();
    +1269     jasmine.Clock.installed = jasmine.Clock.real;
    +1270   },
    +1271 
    +1272   real: {
    +1273     setTimeout: window.setTimeout,
    +1274     clearTimeout: window.clearTimeout,
    +1275     setInterval: window.setInterval,
    +1276     clearInterval: window.clearInterval
    +1277   },
    +1278 
    +1279   assertInstalled: function() {
    +1280     if (jasmine.Clock.installed != jasmine.Clock.defaultFakeTimer) {
    +1281       throw new Error("Mock clock is not installed, use jasmine.Clock.useMock()");
    +1282     }
    +1283   },  
    +1284 
    +1285   installed: null
    +1286 };
    +1287 jasmine.Clock.installed = jasmine.Clock.real;
    +1288 
    +1289 window.setTimeout = function(funcToCall, millis) {
    +1290   return jasmine.Clock.installed.setTimeout.apply(this, arguments);
    +1291 };
    +1292 
    +1293 window.setInterval = function(funcToCall, millis) {
    +1294   return jasmine.Clock.installed.setInterval.apply(this, arguments);
    +1295 };
    +1296 
    +1297 window.clearTimeout = function(timeoutKey) {
    +1298   return jasmine.Clock.installed.clearTimeout.apply(this, arguments);
    +1299 };
    +1300 
    +1301 window.clearInterval = function(timeoutKey) {
    +1302   return jasmine.Clock.installed.clearInterval.apply(this, arguments);
    +1303 };
    +1304 
    +1305 /**
    +1306  * @constructor
    +1307  */
    +1308 jasmine.MultiReporter = function() {
    +1309   this.subReporters_ = [];
    +1310 };
    +1311 jasmine.util.inherit(jasmine.MultiReporter, jasmine.Reporter);
    +1312 
    +1313 jasmine.MultiReporter.prototype.addReporter = function(reporter) {
    +1314   this.subReporters_.push(reporter);
    +1315 };
    +1316 
    +1317 (function() {
    +1318   var functionNames = ["reportRunnerStarting", "reportRunnerResults", "reportSuiteResults", "reportSpecResults", "log"];
    +1319   for (var i = 0; i < functionNames.length; i++) {
    +1320     var functionName = functionNames[i];
    +1321     jasmine.MultiReporter.prototype[functionName] = (function(functionName) {
    +1322       return function() {
    +1323         for (var j = 0; j < this.subReporters_.length; j++) {
    +1324           var subReporter = this.subReporters_[j];
    +1325           if (subReporter[functionName]) {
    +1326             subReporter[functionName].apply(subReporter, arguments);
    +1327           }
    +1328         }
    +1329       };
    +1330     })(functionName);
    +1331   }
    +1332 })();
    +1333 /**
    +1334  * Holds results for a set of Jasmine spec. Allows for the results array to hold another jasmine.NestedResults
    +1335  *
    +1336  * @constructor
    +1337  */
    +1338 jasmine.NestedResults = function() {
    +1339   /**
    +1340    * The total count of results
    +1341    */
    +1342   this.totalCount = 0;
    +1343   /**
    +1344    * Number of passed results
    +1345    */
    +1346   this.passedCount = 0;
    +1347   /**
    +1348    * Number of failed results
    +1349    */
    +1350   this.failedCount = 0;
    +1351   /**
    +1352    * Was this suite/spec skipped?
    +1353    */
    +1354   this.skipped = false;
    +1355   /**
    +1356    * @ignore
    +1357    */
    +1358   this.items_ = [];
    +1359 };
    +1360 
    +1361 /**
    +1362  * Roll up the result counts.
    +1363  *
    +1364  * @param result
    +1365  */
    +1366 jasmine.NestedResults.prototype.rollupCounts = function(result) {
    +1367   this.totalCount += result.totalCount;
    +1368   this.passedCount += result.passedCount;
    +1369   this.failedCount += result.failedCount;
    +1370 };
    +1371 
    +1372 /**
    +1373  * Tracks a result's message.
    +1374  * @param message
    +1375  */
    +1376 jasmine.NestedResults.prototype.log = function(message) {
    +1377   this.items_.push(new jasmine.MessageResult(message));
    +1378 };
    +1379 
    +1380 /**
    +1381  * Getter for the results: message & results.
    +1382  */
    +1383 jasmine.NestedResults.prototype.getItems = function() {
    +1384   return this.items_;
    +1385 };
    +1386 
    +1387 /**
    +1388  * Adds a result, tracking counts (total, passed, & failed)
    +1389  * @param {jasmine.ExpectationResult|jasmine.NestedResults} result
    +1390  */
    +1391 jasmine.NestedResults.prototype.addResult = function(result) {
    +1392   if (result.type != 'MessageResult') {
    +1393     if (result.items_) {
    +1394       this.rollupCounts(result);
    +1395     } else {
    +1396       this.totalCount++;
    +1397       if (result.passed) {
    +1398         this.passedCount++;
    +1399       } else {
    +1400         this.failedCount++;
    +1401       }
    +1402     }
    +1403   }
    +1404   this.items_.push(result);
    +1405 };
    +1406 
    +1407 /**
    +1408  * @returns {Boolean} True if <b>everything</b> below passed
    +1409  */
    +1410 jasmine.NestedResults.prototype.passed = function() {
    +1411   return this.passedCount === this.totalCount;
    +1412 };
    +1413 /**
    +1414  * Base class for pretty printing for expectation results.
    +1415  */
    +1416 jasmine.PrettyPrinter = function() {
    +1417   this.ppNestLevel_ = 0;
    +1418 };
    +1419 
    +1420 /**
    +1421  * Formats a value in a nice, human-readable string.
    +1422  *
    +1423  * @param value
    +1424  * @returns {String}
    +1425  */
    +1426 jasmine.PrettyPrinter.prototype.format = function(value) {
    +1427   if (this.ppNestLevel_ > 40) {
    +1428     //    return '(jasmine.pp nested too deeply!)';
    +1429     throw new Error('jasmine.PrettyPrinter: format() nested too deeply!');
    +1430   }
    +1431 
    +1432   this.ppNestLevel_++;
    +1433   try {
    +1434     if (value === undefined) {
    +1435       this.emitScalar('undefined');
    +1436     } else if (value === null) {
    +1437       this.emitScalar('null');
    +1438     } else if (value.navigator && value.frames && value.setTimeout) {
    +1439       this.emitScalar('<window>');
    +1440     } else if (value instanceof jasmine.Matchers.Any) {
    +1441       this.emitScalar(value.toString());
    +1442     } else if (typeof value === 'string') {
    +1443       this.emitScalar("'" + value + "'");
    +1444     } else if (typeof value === 'function') {
    +1445       this.emitScalar('Function');
    +1446     } else if (typeof value.nodeType === 'number') {
    +1447       this.emitScalar('HTMLNode');
    +1448     } else if (value instanceof Date) {
    +1449       this.emitScalar('Date(' + value + ')');
    +1450     } else if (value.__Jasmine_been_here_before__) {
    +1451       this.emitScalar('<circular reference: ' + (jasmine.isArray_(value) ? 'Array' : 'Object') + '>');
    +1452     } else if (jasmine.isArray_(value) || typeof value == 'object') {
    +1453       value.__Jasmine_been_here_before__ = true;
    +1454       if (jasmine.isArray_(value)) {
    +1455         this.emitArray(value);
    +1456       } else {
    +1457         this.emitObject(value);
    +1458       }
    +1459       delete value.__Jasmine_been_here_before__;
    +1460     } else {
    +1461       this.emitScalar(value.toString());
    +1462     }
    +1463   } finally {
    +1464     this.ppNestLevel_--;
    +1465   }
    +1466 };
    +1467 
    +1468 jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
    +1469   for (var property in obj) {
    +1470     if (property == '__Jasmine_been_here_before__') continue;
    +1471     fn(property, obj.__lookupGetter__(property) != null);
    +1472   }
    +1473 };
    +1474 
    +1475 jasmine.PrettyPrinter.prototype.emitArray = jasmine.unimplementedMethod_;
    +1476 jasmine.PrettyPrinter.prototype.emitObject = jasmine.unimplementedMethod_;
    +1477 jasmine.PrettyPrinter.prototype.emitScalar = jasmine.unimplementedMethod_;
    +1478 
    +1479 jasmine.StringPrettyPrinter = function() {
    +1480   jasmine.PrettyPrinter.call(this);
    +1481 
    +1482   this.string = '';
    +1483 };
    +1484 jasmine.util.inherit(jasmine.StringPrettyPrinter, jasmine.PrettyPrinter);
    +1485 
    +1486 jasmine.StringPrettyPrinter.prototype.emitScalar = function(value) {
    +1487   this.append(value);
    +1488 };
    +1489 
    +1490 jasmine.StringPrettyPrinter.prototype.emitArray = function(array) {
    +1491   this.append('[ ');
    +1492   for (var i = 0; i < array.length; i++) {
    +1493     if (i > 0) {
    +1494       this.append(', ');
    +1495     }
    +1496     this.format(array[i]);
    +1497   }
    +1498   this.append(' ]');
    +1499 };
    +1500 
    +1501 jasmine.StringPrettyPrinter.prototype.emitObject = function(obj) {
    +1502   var self = this;
    +1503   this.append('{ ');
    +1504   var first = true;
    +1505 
    +1506   this.iterateObject(obj, function(property, isGetter) {
    +1507     if (first) {
    +1508       first = false;
    +1509     } else {
    +1510       self.append(', ');
    +1511     }
    +1512 
    +1513     self.append(property);
    +1514     self.append(' : ');
    +1515     if (isGetter) {
    +1516       self.append('<getter>');
    +1517     } else {
    +1518       self.format(obj[property]);
    +1519     }
    +1520   });
    +1521 
    +1522   this.append(' }');
    +1523 };
    +1524 
    +1525 jasmine.StringPrettyPrinter.prototype.append = function(value) {
    +1526   this.string += value;
    +1527 };
    +1528 /**
    +1529  * QueuedFunction is how ActionCollections' actions are implemented
    +1530  *
    +1531  * @constructor
    +1532  * @param {jasmine.Env} env
    +1533  * @param {Function} func
    +1534  * @param {Number} timeout
    +1535  * @param {Function} latchFunction
    +1536  * @param {jasmine.Spec} spec
    +1537  */
    +1538 jasmine.QueuedFunction = function(env, func, timeout, latchFunction, spec) {
    +1539   this.env = env;
    +1540   this.func = func;
    +1541   this.timeout = timeout;
    +1542   this.latchFunction = latchFunction;
    +1543   this.spec = spec;
    +1544 
    +1545   this.totalTimeSpentWaitingForLatch = 0;
    +1546   this.latchTimeoutIncrement = 100;
    +1547 };
    +1548 
    +1549 jasmine.QueuedFunction.prototype.next = function() {
    +1550   this.spec.finish(); // default value is to be done after one function
    +1551 };
    +1552 
    +1553 jasmine.QueuedFunction.prototype.safeExecute = function() {
    +1554   this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...');
    +1555 
    +1556   try {
    +1557     this.func.apply(this.spec);
    +1558   } catch (e) {
    +1559     this.fail(e);
    +1560   }
    +1561 };
    +1562 
    +1563 jasmine.QueuedFunction.prototype.execute = function() {
    +1564   var self = this;
    +1565   var executeNow = function() {
    +1566     self.safeExecute();
    +1567     self.next();
    +1568   };
    +1569 
    +1570   var executeLater = function() {
    +1571     self.env.setTimeout(executeNow, self.timeout);
    +1572   };
    +1573 
    +1574   var executeNowOrLater = function() {
    +1575     var latchFunctionResult;
    +1576 
    +1577     try {
    +1578       latchFunctionResult = self.latchFunction.apply(self.spec);
    +1579     } catch (e) {
    +1580       self.fail(e);
    +1581       self.next();
    +1582       return;
    +1583     }
    +1584 
    +1585     if (latchFunctionResult) {
    +1586       executeNow();
    +1587     } else if (self.totalTimeSpentWaitingForLatch >= self.timeout) {
    +1588       var message = 'timed out after ' + self.timeout + ' msec waiting for ' + (self.latchFunction.description || 'something to happen');
    +1589       self.fail({
    +1590         name: 'timeout',
    +1591         message: message
    +1592       });
    +1593       self.next();
    +1594     } else {
    +1595       self.totalTimeSpentWaitingForLatch += self.latchTimeoutIncrement;
    +1596       self.env.setTimeout(executeNowOrLater, self.latchTimeoutIncrement);
    +1597     }
    +1598   };
    +1599 
    +1600   if (this.latchFunction !== undefined) {
    +1601     executeNowOrLater();
    +1602   } else if (this.timeout > 0) {
    +1603     executeLater();
    +1604   } else {
    +1605     executeNow();
    +1606   }
    +1607 };
    +1608 
    +1609 jasmine.QueuedFunction.prototype.fail = function(e) {
    +1610   this.spec.results.addResult(new jasmine.ExpectationResult(false, jasmine.util.formatException(e), null));
    +1611 };
    +1612 /* JasmineReporters.reporter
    +1613  *    Base object that will get called whenever a Spec, Suite, or Runner is done.  It is up to
    +1614  *    descendants of this object to do something with the results (see json_reporter.js)
    +1615  */
    +1616 jasmine.Reporters = {};
    +1617 
    +1618 jasmine.Reporters.reporter = function(callbacks) {
    +1619   var that = {
    +1620     callbacks: callbacks || {},
    +1621 
    +1622     doCallback: function(callback, results) {
    +1623       if (callback) {
    +1624         callback(results);
    +1625       }
    +1626     },
    +1627 
    +1628     reportRunnerResults: function(runner) {
    +1629       that.doCallback(that.callbacks.runnerCallback, runner);
    +1630     },
    +1631     reportSuiteResults:  function(suite) {
    +1632       that.doCallback(that.callbacks.suiteCallback, suite);
    +1633     },
    +1634     reportSpecResults:   function(spec) {
    +1635       that.doCallback(that.callbacks.specCallback, spec);
    +1636     },
    +1637     log: function (str) {
    +1638       if (console && console.log) console.log(str);
    +1639     }
    +1640   };
    +1641 
    +1642   return that;
    +1643 };
    +1644 
    +1645 /**
    +1646  * Runner
    +1647  *
    +1648  * @constructor
    +1649  * @param {jasmine.Env} env
    +1650  */
    +1651 jasmine.Runner = function(env) {
    +1652   jasmine.ActionCollection.call(this, env);
    +1653 
    +1654   this.suites = this.actions;
    +1655 };
    +1656 jasmine.util.inherit(jasmine.Runner, jasmine.ActionCollection);
    +1657 
    +1658 jasmine.Runner.prototype.execute = function() {
    +1659   if (this.env.reporter.reportRunnerStarting) {
    +1660     this.env.reporter.reportRunnerStarting(this);
    +1661   }
    +1662   jasmine.ActionCollection.prototype.execute.call(this);
    +1663 };
    +1664 
    +1665 jasmine.Runner.prototype.finishCallback = function() {
    +1666   this.env.reporter.reportRunnerResults(this);
    +1667 };
    +1668 
    +1669 jasmine.Runner.prototype.getResults = function() {
    +1670   var results = new jasmine.NestedResults();
    +1671   for (var i = 0; i < this.suites.length; i++) {
    +1672     results.rollupCounts(this.suites[i].getResults());
    +1673   }
    +1674   return results;
    +1675 };
    +1676 /**
    +1677  * Internal representation of a Jasmine specification, or test.
    +1678  *
    +1679  * @constructor
    +1680  * @param {jasmine.Env} env
    +1681  * @param {jasmine.Suite} suite
    +1682  * @param {String} description
    +1683  */
    +1684 jasmine.Spec = function(env, suite, description) {
    +1685   this.id = env.nextSpecId_++;
    +1686   this.env = env;
    +1687   this.suite = suite;
    +1688   this.description = description;
    +1689   this.queue = [];
    +1690   this.currentTimeout = 0;
    +1691   this.currentLatchFunction = undefined;
    +1692   this.finished = false;
    +1693   this.afterCallbacks = [];
    +1694   this.spies_ = [];
    +1695 
    +1696   this.results = new jasmine.NestedResults();
    +1697   this.results.description = description;
    +1698   this.runs = this.addToQueue;
    +1699   this.matchersClass = null;
    +1700 };
    +1701 
    +1702 jasmine.Spec.prototype.getFullName = function() {
    +1703   return this.suite.getFullName() + ' ' + this.description + '.';
    +1704 };
    +1705 
    +1706 jasmine.Spec.prototype.getResults = function() {
    +1707   return this.results;
    +1708 };
    +1709 
    +1710 jasmine.Spec.prototype.addToQueue = function(func) {
    +1711   var queuedFunction = new jasmine.QueuedFunction(this.env, func, this.currentTimeout, this.currentLatchFunction, this);
    +1712   this.queue.push(queuedFunction);
    +1713 
    +1714   if (this.queue.length > 1) {
    +1715     var previousQueuedFunction = this.queue[this.queue.length - 2];
    +1716     previousQueuedFunction.next = function() {
    +1717       queuedFunction.execute();
    +1718     };
    +1719   }
    +1720 
    +1721   this.resetTimeout();
    +1722   return this;
    +1723 };
    +1724 
    +1725 /**
    +1726  * @private
    +1727  * @deprecated
    +1728  */
    +1729 jasmine.Spec.prototype.expects_that = function(actual) {
    +1730   return this.expect(actual);
    +1731 };
    +1732 
    +1733 /**
    +1734  * @private
    +1735  */
    +1736 jasmine.Spec.prototype.expect = function(actual) {
    +1737   return new (this.getMatchersClass_())(this.env, actual, this.results);
    +1738 };
    +1739 
    +1740 /**
    +1741  * @private
    +1742  */
    +1743 jasmine.Spec.prototype.waits = function(timeout) {
    +1744   this.currentTimeout = timeout;
    +1745   this.currentLatchFunction = undefined;
    +1746   return this;
    +1747 };
    +1748 
    +1749 /**
    +1750  * @private
    +1751  */
    +1752 jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, message) {
    +1753   this.currentTimeout = timeout;
    +1754   this.currentLatchFunction = latchFunction;
    +1755   this.currentLatchFunction.description = message;
    +1756   return this;
    +1757 };
    +1758 
    +1759 jasmine.Spec.prototype.getMatchersClass_ = function() {
    +1760   return this.matchersClass || jasmine.Matchers;
    +1761 };
    +1762 
    +1763 jasmine.Spec.prototype.addMatchers = function(matchersPrototype) {
    +1764   var parent = this.getMatchersClass_();
    +1765   var newMatchersClass = function() {
    +1766     parent.apply(this, arguments);
    +1767   };
    +1768   jasmine.util.inherit(newMatchersClass, parent);
    +1769   for (var method in matchersPrototype) {
    +1770     newMatchersClass.prototype[method] = matchersPrototype[method];
    +1771   }
    +1772   this.matchersClass = newMatchersClass;
    +1773 };
    +1774 
    +1775 jasmine.Spec.prototype.resetTimeout = function() {
    +1776   this.currentTimeout = 0;
    +1777   this.currentLatchFunction = undefined;
    +1778 };
    +1779 
    +1780 jasmine.Spec.prototype.finishCallback = function() {
    +1781   this.env.reporter.reportSpecResults(this);
    +1782 };
    +1783 
    +1784 jasmine.Spec.prototype.finish = function() {
    +1785   this.safeExecuteAfters();
    +1786 
    +1787   this.removeAllSpies();
    +1788   this.finishCallback();
    +1789   this.finished = true;
    +1790 };
    +1791 
    +1792 jasmine.Spec.prototype.after = function(doAfter) {
    +1793   this.afterCallbacks.unshift(doAfter);
    +1794 };
    +1795 
    +1796 jasmine.Spec.prototype.execute = function() {
    +1797   if (!this.env.specFilter(this)) {
    +1798     this.results.skipped = true;
    +1799     this.finishCallback();
    +1800     this.finished = true;
    +1801     return;
    +1802   }
    +1803 
    +1804   this.env.currentSpec = this;
    +1805   this.env.currentlyRunningTests = true;
    +1806 
    +1807   this.safeExecuteBefores();
    +1808 
    +1809   if (this.queue[0]) {
    +1810     this.queue[0].execute();
    +1811   } else {
    +1812     this.finish();
    +1813   }
    +1814   this.env.currentlyRunningTests = false;
    +1815 };
    +1816 
    +1817 jasmine.Spec.prototype.safeExecuteBefores = function() {
    +1818   var befores = [];
    +1819   for (var suite = this.suite; suite; suite = suite.parentSuite) {
    +1820     if (suite.beforeEachFunction) befores.push(suite.beforeEachFunction);
    +1821   }
    +1822 
    +1823   while (befores.length) {
    +1824     this.safeExecuteBeforeOrAfter(befores.pop());
    +1825   }
    +1826 };
    +1827 
    +1828 jasmine.Spec.prototype.safeExecuteAfters = function() {
    +1829   for (var suite = this.suite; suite; suite = suite.parentSuite) {
    +1830     if (suite.afterEachFunction) this.safeExecuteBeforeOrAfter(suite.afterEachFunction);
    +1831   }
    +1832 };
    +1833 
    +1834 jasmine.Spec.prototype.safeExecuteBeforeOrAfter = function(func) {
    +1835   try {
    +1836     func.apply(this);
    +1837   } catch (e) {
    +1838     this.results.addResult(new jasmine.ExpectationResult(false, func.typeName + '() fail: ' + jasmine.util.formatException(e), null));
    +1839   }
    +1840 };
    +1841 
    +1842 jasmine.Spec.prototype.explodes = function() {
    +1843   throw 'explodes function should not have been called';
    +1844 };
    +1845 
    +1846 jasmine.Spec.prototype.spyOn = function(obj, methodName, ignoreMethodDoesntExist) {
    +1847   if (obj == undefined) {
    +1848     throw "spyOn could not find an object to spy upon for " + methodName + "()";
    +1849   }
    +1850 
    +1851   if (!ignoreMethodDoesntExist && obj[methodName] === undefined) {
    +1852     throw methodName + '() method does not exist';
    +1853   }
    +1854 
    +1855   if (!ignoreMethodDoesntExist && obj[methodName] && obj[methodName].isSpy) {
    +1856     throw new Error(methodName + ' has already been spied upon');
    +1857   }
    +1858 
    +1859   var spyObj = jasmine.createSpy(methodName);
    +1860 
    +1861   this.spies_.push(spyObj);
    +1862   spyObj.baseObj = obj;
    +1863   spyObj.methodName = methodName;
    +1864   spyObj.originalValue = obj[methodName];
    +1865 
    +1866   obj[methodName] = spyObj;
    +1867 
    +1868   return spyObj;
    +1869 };
    +1870 
    +1871 jasmine.Spec.prototype.removeAllSpies = function() {
    +1872   for (var i = 0; i < this.spies_.length; i++) {
    +1873     var spy = this.spies_[i];
    +1874     spy.baseObj[spy.methodName] = spy.originalValue;
    +1875   }
    +1876   this.spies_ = [];
    +1877 };
    +1878 
    +1879 /**
    +1880  * Internal representation of a Jasmine suite.
    +1881  *
    +1882  * @constructor
    +1883  * @param {jasmine.Env} env
    +1884  * @param {String} description
    +1885  * @param {Function} specDefinitions
    +1886  * @param {jasmine.Suite} parentSuite
    +1887  */
    +1888 jasmine.Suite = function(env, description, specDefinitions, parentSuite) {
    +1889   jasmine.ActionCollection.call(this, env);
    +1890 
    +1891   this.description = description;
    +1892   this.specs = this.actions;
    +1893   this.parentSuite = parentSuite;
    +1894 
    +1895   this.beforeEachFunction = null;
    +1896   this.afterEachFunction = null;
    +1897 };
    +1898 jasmine.util.inherit(jasmine.Suite, jasmine.ActionCollection);
    +1899 
    +1900 jasmine.Suite.prototype.getFullName = function() {
    +1901   var fullName = this.description;
    +1902   for (var parentSuite = this.parentSuite; parentSuite; parentSuite = parentSuite.parentSuite) {
    +1903     fullName = parentSuite.description + ' ' + fullName;
    +1904   }
    +1905   return fullName;
    +1906 };
    +1907 
    +1908 jasmine.Suite.prototype.finishCallback = function() {
    +1909   this.env.reporter.reportSuiteResults(this);
    +1910 };
    +1911 
    +1912 jasmine.Suite.prototype.beforeEach = function(beforeEachFunction) {
    +1913   beforeEachFunction.typeName = 'beforeEach';
    +1914   this.beforeEachFunction = beforeEachFunction;
    +1915 };
    +1916 
    +1917 jasmine.Suite.prototype.afterEach = function(afterEachFunction) {
    +1918   afterEachFunction.typeName = 'afterEach';
    +1919   this.afterEachFunction = afterEachFunction;
    +1920 };
    +1921 
    +1922 jasmine.Suite.prototype.getResults = function() {
    +1923   var results = new jasmine.NestedResults();
    +1924   for (var i = 0; i < this.specs.length; i++) {
    +1925     results.rollupCounts(this.specs[i].getResults());
    +1926   }
    +1927   return results;
    +1928 };
    +1929 
    +1930 
    \ No newline at end of file diff --git a/doc/symbols/src/src_ActionCollection.js.html b/doc/symbols/src/src_ActionCollection.js.html deleted file mode 100644 index 45b2abb..0000000 --- a/doc/symbols/src/src_ActionCollection.js.html +++ /dev/null @@ -1,100 +0,0 @@ -
      1 /**
    -  2  * base for Runner & Suite: allows for a queue of functions to get executed, allowing for
    -  3  *   any one action to complete, including asynchronous calls, before going to the next
    -  4  *   action.
    -  5  *
    -  6  * @constructor
    -  7  * @param {jasmine.Env} env
    -  8  */
    -  9 jasmine.ActionCollection = function(env) {
    - 10   this.env = env;
    - 11   this.actions = [];
    - 12   this.index = 0;
    - 13   this.finished = false;
    - 14 };
    - 15 
    - 16 /**
    - 17  * Marks the collection as done & calls the finish callback, if there is one
    - 18  */
    - 19 jasmine.ActionCollection.prototype.finish = function() {
    - 20   if (this.finishCallback) {
    - 21     this.finishCallback();
    - 22   }
    - 23   this.finished = true;
    - 24 };
    - 25 
    - 26 /**
    - 27  * Starts executing the queue of functions/actions.
    - 28  */
    - 29 jasmine.ActionCollection.prototype.execute = function() {
    - 30   if (this.actions.length > 0) {
    - 31     this.next();
    - 32   }
    - 33 };
    - 34 
    - 35 /**
    - 36  * Gets the current action.
    - 37  */
    - 38 jasmine.ActionCollection.prototype.getCurrentAction = function() {
    - 39   return this.actions[this.index];
    - 40 };
    - 41 
    - 42 /**
    - 43  * Executes the next queued function/action. If there are no more in the queue, calls #finish.
    - 44  */
    - 45 jasmine.ActionCollection.prototype.next = function() {
    - 46   if (this.index >= this.actions.length) {
    - 47     this.finish();
    - 48     return;
    - 49   }
    - 50 
    - 51   var currentAction = this.getCurrentAction();
    - 52 
    - 53   currentAction.execute(this);
    - 54 
    - 55   if (currentAction.afterCallbacks) {
    - 56     for (var i = 0; i < currentAction.afterCallbacks.length; i++) {
    - 57       try {
    - 58         currentAction.afterCallbacks[i]();
    - 59       } catch (e) {
    - 60         alert(e);
    - 61       }
    - 62     }
    - 63   }
    - 64 
    - 65   this.waitForDone(currentAction);
    - 66 };
    - 67 
    - 68 jasmine.ActionCollection.prototype.waitForDone = function(action) {
    - 69   var self = this;
    - 70   var afterExecute = function afterExecute() {
    - 71     self.index++;
    - 72     self.next();
    - 73   };
    - 74 
    - 75   if (action.finished) {
    - 76     var now = new Date().getTime();
    - 77     if (this.env.updateInterval && now - this.env.lastUpdate > this.env.updateInterval) {
    - 78       this.env.lastUpdate = now;
    - 79       this.env.setTimeout(afterExecute, 0);
    - 80     } else {
    - 81       afterExecute();
    - 82     }
    - 83     return;
    - 84   }
    - 85 
    - 86   var id = this.env.setInterval(function() {
    - 87     if (action.finished) {
    - 88       self.env.clearInterval(id);
    - 89       afterExecute();
    - 90     }
    - 91   }, 150);
    - 92 };
    - 93 
    \ No newline at end of file diff --git a/doc/symbols/src/src_Env.js.html b/doc/symbols/src/src_Env.js.html deleted file mode 100644 index bf486e9..0000000 --- a/doc/symbols/src/src_Env.js.html +++ /dev/null @@ -1,179 +0,0 @@ -
      1 jasmine.Env = function() {
    -  2   this.currentSpec = null;
    -  3   this.currentSuite = null;
    -  4   this.currentRunner = new jasmine.Runner(this);
    -  5   this.currentlyRunningTests = false;
    -  6 
    -  7   this.updateInterval = 0;
    -  8   this.lastUpdate = 0;
    -  9   this.specFilter = function() {
    - 10     return true;
    - 11   };
    - 12 
    - 13   this.nextSpecId_ = 0;
    - 14   this.equalityTesters_ = [];
    - 15 };
    - 16 
    - 17 
    - 18 jasmine.Env.prototype.setTimeout = jasmine.setTimeout;
    - 19 jasmine.Env.prototype.clearTimeout = jasmine.clearTimeout;
    - 20 jasmine.Env.prototype.setInterval = jasmine.setInterval;
    - 21 jasmine.Env.prototype.clearInterval = jasmine.clearInterval;
    - 22 
    - 23 jasmine.Env.prototype.execute = function() {
    - 24   this.currentRunner.execute();
    - 25 };
    - 26 
    - 27 jasmine.Env.prototype.describe = function(description, specDefinitions) {
    - 28   var suite = new jasmine.Suite(this, description, specDefinitions, this.currentSuite);
    - 29 
    - 30   var parentSuite = this.currentSuite;
    - 31   if (parentSuite) {
    - 32     parentSuite.specs.push(suite);
    - 33   } else {
    - 34     this.currentRunner.suites.push(suite);
    - 35   }
    - 36 
    - 37   this.currentSuite = suite;
    - 38 
    - 39   specDefinitions.call(suite);
    - 40 
    - 41   this.currentSuite = parentSuite;
    - 42 
    - 43   return suite;
    - 44 };
    - 45 
    - 46 jasmine.Env.prototype.beforeEach = function(beforeEachFunction) {
    - 47   this.currentSuite.beforeEach(beforeEachFunction);
    - 48 };
    - 49 
    - 50 jasmine.Env.prototype.afterEach = function(afterEachFunction) {
    - 51   this.currentSuite.afterEach(afterEachFunction);
    - 52 };
    - 53 
    - 54 jasmine.Env.prototype.xdescribe = function(desc, specDefinitions) {
    - 55   return {
    - 56     execute: function() {
    - 57     }
    - 58   };
    - 59 };
    - 60 
    - 61 jasmine.Env.prototype.it = function(description, func) {
    - 62   var spec = new jasmine.Spec(this, this.currentSuite, description);
    - 63   this.currentSuite.specs.push(spec);
    - 64   this.currentSpec = spec;
    - 65 
    - 66   if (func) {
    - 67     spec.addToQueue(func);
    - 68   }
    - 69 
    - 70   return spec;
    - 71 };
    - 72 
    - 73 jasmine.Env.prototype.xit = function(desc, func) {
    - 74   return {
    - 75     id: this.nextSpecId_++,
    - 76     runs: function() {
    - 77     }
    - 78   };
    - 79 };
    - 80 
    - 81 jasmine.Env.prototype.compareObjects_ = function(a, b, mismatchKeys, mismatchValues) {
    - 82   if (a.__Jasmine_been_here_before__ === b && b.__Jasmine_been_here_before__ === a) {
    - 83     return true;
    - 84   }
    - 85 
    - 86   a.__Jasmine_been_here_before__ = b;
    - 87   b.__Jasmine_been_here_before__ = a;
    - 88 
    - 89   var hasKey = function(obj, keyName) {
    - 90     return obj != null && obj[keyName] !== undefined;
    - 91   };
    - 92 
    - 93   for (var property in b) {
    - 94     if (!hasKey(a, property) && hasKey(b, property)) {
    - 95       mismatchKeys.push("expected has key '" + property + "', but missing from <b>actual</b>.");
    - 96     }
    - 97   }
    - 98   for (property in a) {
    - 99     if (!hasKey(b, property) && hasKey(a, property)) {
    -100       mismatchKeys.push("<b>expected</b> missing key '" + property + "', but present in actual.");
    -101     }
    -102   }
    -103   for (property in b) {
    -104     if (property == '__Jasmine_been_here_before__') continue;
    -105     if (!this.equals_(a[property], b[property], mismatchKeys, mismatchValues)) {
    -106       mismatchValues.push("'" + property + "' was<br /><br />'" + (b[property] ? jasmine.util.htmlEscape(b[property].toString()) : b[property]) + "'<br /><br />in expected, but was<br /><br />'" + (a[property] ? jasmine.util.htmlEscape(a[property].toString()) : a[property]) + "'<br /><br />in actual.<br />");
    -107     }
    -108   }
    -109 
    -110   if (jasmine.isArray_(a) && jasmine.isArray_(b) && a.length != b.length) {
    -111     mismatchValues.push("arrays were not the same length");
    -112   }
    -113 
    -114   delete a.__Jasmine_been_here_before__;
    -115   delete b.__Jasmine_been_here_before__;
    -116   return (mismatchKeys.length == 0 && mismatchValues.length == 0);
    -117 };
    -118 
    -119 jasmine.Env.prototype.equals_ = function(a, b, mismatchKeys, mismatchValues) {
    -120   mismatchKeys = mismatchKeys || [];
    -121   mismatchValues = mismatchValues || [];
    -122 
    -123   if (a === b) return true;
    -124 
    -125   if (a === undefined || a === null || b === undefined || b === null) {
    -126     return (a == undefined && b == undefined);
    -127   }
    -128 
    -129   if (jasmine.isDomNode(a) && jasmine.isDomNode(b)) {
    -130     return a === b;
    -131   }
    -132 
    -133   if (a instanceof Date && b instanceof Date) {
    -134     return a.getTime() == b.getTime();
    -135   }
    -136 
    -137   if (a instanceof jasmine.Matchers.Any) {
    -138     return a.matches(b);
    -139   }
    -140 
    -141   if (b instanceof jasmine.Matchers.Any) {
    -142     return b.matches(a);
    -143   }
    -144 
    -145   if (typeof a === "object" && typeof b === "object") {
    -146     return this.compareObjects_(a, b, mismatchKeys, mismatchValues);
    -147   }
    -148 
    -149   for (var i = 0; i < this.equalityTesters_.length; i++) {
    -150     var equalityTester = this.equalityTesters_[i];
    -151     var result = equalityTester(a, b, this, mismatchKeys, mismatchValues);
    -152     if (result !== undefined) return result;
    -153   }
    -154 
    -155   //Straight check
    -156   return (a === b);
    -157 };
    -158 
    -159 jasmine.Env.prototype.contains_ = function(haystack, needle) {
    -160   if (jasmine.isArray_(haystack)) {
    -161     for (var i = 0; i < haystack.length; i++) {
    -162       if (this.equals_(haystack[i], needle)) return true;
    -163     }
    -164     return false;
    -165   }
    -166   return haystack.indexOf(needle) >= 0;
    -167 };
    -168 
    -169 jasmine.Env.prototype.addEqualityTester = function(equalityTester) {
    -170   this.equalityTesters_.push(equalityTester);
    -171 };
    -172 
    \ No newline at end of file diff --git a/doc/symbols/src/src_Matchers.js.html b/doc/symbols/src/src_Matchers.js.html deleted file mode 100644 index 906d872..0000000 --- a/doc/symbols/src/src_Matchers.js.html +++ /dev/null @@ -1,280 +0,0 @@ -
      1 jasmine.Matchers = function(env, actual, results) {
    -  2   this.env = env;
    -  3   this.actual = actual;
    -  4   this.passing_message = 'Passed.';
    -  5   this.results = results || new jasmine.NestedResults();
    -  6 };
    -  7 
    -  8 jasmine.Matchers.pp = function(str) {
    -  9   return jasmine.util.htmlEscape(jasmine.pp(str));
    - 10 };
    - 11 
    - 12 jasmine.Matchers.prototype.getResults = function() {
    - 13   return this.results;
    - 14 };
    - 15 
    - 16 jasmine.Matchers.prototype.report = function(result, failing_message, details) {
    - 17   this.results.addResult(new jasmine.ExpectationResult(result, result ? this.passing_message : failing_message, details));
    - 18   return result;
    - 19 };
    - 20 
    - 21 /**
    - 22  * Matcher that compares the actual to the expected using ===.
    - 23  *
    - 24  * @param expected
    - 25  */
    - 26 jasmine.Matchers.prototype.toBe = function(expected) {
    - 27   return this.report(this.actual === expected, 'Expected<br /><br />' + jasmine.Matchers.pp(expected)
    - 28     + '<br /><br />to be the same object as<br /><br />' + jasmine.Matchers.pp(this.actual)
    - 29     + '<br />');
    - 30 };
    - 31 
    - 32 /**
    - 33  * Matcher that compares the actual to the expected using !==
    - 34  * @param expected
    - 35  */
    - 36 jasmine.Matchers.prototype.toNotBe = function(expected) {
    - 37   return this.report(this.actual !== expected, 'Expected<br /><br />' + jasmine.Matchers.pp(expected)
    - 38     + '<br /><br />to be a different object from actual, but they were the same.');
    - 39 };
    - 40 
    - 41 /**
    - 42  * Matcher that compares the actual to the expected using common sense equality. Handles Objects, Arrays, etc.
    - 43  *
    - 44  * @param expected
    - 45  */
    - 46 jasmine.Matchers.prototype.toEqual = function(expected) {
    - 47   var mismatchKeys = [];
    - 48   var mismatchValues = [];
    - 49 
    - 50   var formatMismatches = function(name, array) {
    - 51     if (array.length == 0) return '';
    - 52     var errorOutput = '<br /><br />Different ' + name + ':<br />';
    - 53     for (var i = 0; i < array.length; i++) {
    - 54       errorOutput += array[i] + '<br />';
    - 55     }
    - 56     return errorOutput;
    - 57   };
    - 58 
    - 59   return this.report(this.env.equals_(this.actual, expected, mismatchKeys, mismatchValues),
    - 60     'Expected<br /><br />' + jasmine.Matchers.pp(expected)
    - 61       + '<br /><br />but got<br /><br />' + jasmine.Matchers.pp(this.actual)
    - 62       + '<br />'
    - 63       + formatMismatches('Keys', mismatchKeys)
    - 64       + formatMismatches('Values', mismatchValues), {
    - 65     matcherName: 'toEqual', expected: expected, actual: this.actual
    - 66   });
    - 67 };
    - 68 /** @deprecated */
    - 69 jasmine.Matchers.prototype.should_equal = jasmine.Matchers.prototype.toEqual;
    - 70 
    - 71 /**
    - 72  * Matcher that compares the actual to the expected using the ! of jasmine.Matchers.toEqual
    - 73  * @param expected
    - 74  */
    - 75 jasmine.Matchers.prototype.toNotEqual = function(expected) {
    - 76   return this.report(!this.env.equals_(this.actual, expected),
    - 77     'Expected ' + jasmine.Matchers.pp(expected) + ' to not equal ' + jasmine.Matchers.pp(this.actual) + ', but it does.');
    - 78 };
    - 79 /** @deprecated */
    - 80 jasmine.Matchers.prototype.should_not_equal = jasmine.Matchers.prototype.toNotEqual;
    - 81 
    - 82 /**
    - 83  * Matcher that compares the actual to the expected using a regular expression.  Constructs a RegExp, so takes
    - 84  * a pattern or a String.
    - 85  *
    - 86  * @param reg_exp
    - 87  */
    - 88 jasmine.Matchers.prototype.toMatch = function(reg_exp) {
    - 89   return this.report((new RegExp(reg_exp).test(this.actual)),
    - 90     'Expected ' + jasmine.Matchers.pp(this.actual) + ' to match ' + reg_exp + '.');
    - 91 };
    - 92 /** @deprecated */
    - 93 jasmine.Matchers.prototype.should_match = jasmine.Matchers.prototype.toMatch;
    - 94 
    - 95 /**
    - 96  * Matcher that compares the actual to the expected using the boolean inverse of jasmine.Matchers.toMatch
    - 97  * @param reg_exp
    - 98  */
    - 99 jasmine.Matchers.prototype.toNotMatch = function(reg_exp) {
    -100   return this.report((!new RegExp(reg_exp).test(this.actual)),
    -101     'Expected ' + jasmine.Matchers.pp(this.actual) + ' to not match ' + reg_exp + '.');
    -102 };
    -103 /** @deprecated */
    -104 jasmine.Matchers.prototype.should_not_match = jasmine.Matchers.prototype.toNotMatch;
    -105 
    -106 /**
    -107  * Matcher that compares the acutal to undefined.
    -108  */
    -109 jasmine.Matchers.prototype.toBeDefined = function() {
    -110   return this.report((this.actual !== undefined),
    -111     'Expected a value to be defined but it was undefined.');
    -112 };
    -113 /** @deprecated */
    -114 jasmine.Matchers.prototype.should_be_defined = jasmine.Matchers.prototype.toBeDefined;
    -115 
    -116 /**
    -117  * Matcher that compares the actual to null.
    -118  *
    -119  */
    -120 jasmine.Matchers.prototype.toBeNull = function() {
    -121   return this.report((this.actual === null),
    -122     'Expected a value to be null but it was ' + jasmine.Matchers.pp(this.actual) + '.');
    -123 };
    -124 /** @deprecated */
    -125 jasmine.Matchers.prototype.should_be_null = jasmine.Matchers.prototype.toBeNull;
    -126 
    -127 /**
    -128  * Matcher that boolean not-nots the actual.
    -129  */
    -130 jasmine.Matchers.prototype.toBeTruthy = function() {
    -131   return this.report(!!this.actual,
    -132     'Expected a value to be truthy but it was ' + jasmine.Matchers.pp(this.actual) + '.');
    -133 };
    -134 /** @deprecated */
    -135 jasmine.Matchers.prototype.should_be_truthy = jasmine.Matchers.prototype.toBeTruthy;
    -136 
    -137 /**
    -138  * Matcher that boolean nots the actual.
    -139  */
    -140 jasmine.Matchers.prototype.toBeFalsy = function() {
    -141   return this.report(!this.actual,
    -142     'Expected a value to be falsy but it was ' + jasmine.Matchers.pp(this.actual) + '.');
    -143 };
    -144 /** @deprecated */
    -145 jasmine.Matchers.prototype.should_be_falsy = jasmine.Matchers.prototype.toBeFalsy;
    -146 
    -147 /**
    -148  * Matcher that checks to see if the acutal, a Jasmine spy, was called.
    -149  */
    -150 jasmine.Matchers.prototype.wasCalled = function() {
    -151   if (!this.actual || !this.actual.isSpy) {
    -152     return this.report(false, 'Expected a spy, but got ' + jasmine.Matchers.pp(this.actual) + '.');
    -153   }
    -154   if (arguments.length > 0) {
    -155     return this.report(false, 'wasCalled matcher does not take arguments');
    -156   }
    -157   return this.report((this.actual.wasCalled),
    -158     'Expected spy "' + this.actual.identity + '" to have been called, but it was not.');
    -159 };
    -160 /** @deprecated */
    -161 jasmine.Matchers.prototype.was_called = jasmine.Matchers.prototype.wasCalled;
    -162 
    -163 /**
    -164  * Matcher that checks to see if the acutal, a Jasmine spy, was not called.
    -165  */
    -166 jasmine.Matchers.prototype.wasNotCalled = function() {
    -167   if (!this.actual || !this.actual.isSpy) {
    -168     return this.report(false, 'Expected a spy, but got ' + jasmine.Matchers.pp(this.actual) + '.');
    -169   }
    -170   return this.report((!this.actual.wasCalled),
    -171     'Expected spy "' + this.actual.identity + '" to not have been called, but it was.');
    -172 };
    -173 /** @deprecated */
    -174 jasmine.Matchers.prototype.was_not_called = jasmine.Matchers.prototype.wasNotCalled;
    -175 
    -176 /**
    -177  * Matcher that checks to see if the acutal, a Jasmine spy, was called with a set of parameters.
    -178  *
    -179  * @example
    -180  *
    -181  */
    -182 jasmine.Matchers.prototype.wasCalledWith = function() {
    -183   if (!this.actual || !this.actual.isSpy) {
    -184     return this.report(false, 'Expected a spy, but got ' + jasmine.Matchers.pp(this.actual) + '.', {
    -185       matcherName: 'wasCalledWith'
    -186     });
    -187   }
    -188 
    -189   var args = jasmine.util.argsToArray(arguments);
    -190 
    -191   return this.report(this.env.contains_(this.actual.argsForCall, args),
    -192     'Expected ' + jasmine.Matchers.pp(this.actual.argsForCall) + ' to contain ' + jasmine.Matchers.pp(args) + ', but it does not.', {
    -193     matcherName: 'wasCalledWith', expected: args, actual: this.actual.argsForCall
    -194   });
    -195 };
    -196 
    -197 /**
    -198  * Matcher that checks that the expected item is an element in the actual Array.
    -199  *
    -200  * @param {Object} item
    -201  */
    -202 jasmine.Matchers.prototype.toContain = function(item) {
    -203   return this.report(this.env.contains_(this.actual, item),
    -204     'Expected ' + jasmine.Matchers.pp(this.actual) + ' to contain ' + jasmine.Matchers.pp(item) + ', but it does not.', {
    -205     matcherName: 'toContain', expected: item, actual: this.actual
    -206   });
    -207 };
    -208 
    -209 /**
    -210  * Matcher that checks that the expected item is NOT an element in the actual Array.
    -211  *
    -212  * @param {Object} item
    -213  */
    -214 jasmine.Matchers.prototype.toNotContain = function(item) {
    -215   return this.report(!this.env.contains_(this.actual, item),
    -216     'Expected ' + jasmine.Matchers.pp(this.actual) + ' not to contain ' + jasmine.Matchers.pp(item) + ', but it does.');
    -217 };
    -218 
    -219 /**
    -220  * Matcher that checks that the expected exception was thrown by the actual.
    -221  *
    -222  * @param {String} expectedException
    -223  */
    -224 jasmine.Matchers.prototype.toThrow = function(expectedException) {
    -225   var exception = null;
    -226   try {
    -227     this.actual();
    -228   } catch (e) {
    -229     exception = e;
    -230   }
    -231   if (expectedException !== undefined) {
    -232     if (exception == null) {
    -233       return this.report(false, "Expected function to throw " + jasmine.Matchers.pp(expectedException) + ", but it did not.");
    -234     }
    -235     return this.report(
    -236       this.env.equals_(
    -237         exception.message || exception,
    -238         expectedException.message || expectedException),
    -239       "Expected function to throw " + jasmine.Matchers.pp(expectedException) + ", but it threw " + jasmine.Matchers.pp(exception) + ".");
    -240   } else {
    -241     return this.report(exception != null, "Expected function to throw an exception, but it did not.");
    -242   }
    -243 };
    -244 
    -245 jasmine.Matchers.Any = function(expectedClass) {
    -246   this.expectedClass = expectedClass;
    -247 };
    -248 
    -249 jasmine.Matchers.Any.prototype.matches = function(other) {
    -250   if (this.expectedClass == String) {
    -251     return typeof other == 'string' || other instanceof String;
    -252   }
    -253 
    -254   if (this.expectedClass == Number) {
    -255     return typeof other == 'number' || other instanceof Number;
    -256   }
    -257 
    -258   if (this.expectedClass == Function) {
    -259     return typeof other == 'function' || other instanceof Function;
    -260   }
    -261 
    -262   if (this.expectedClass == Object) {
    -263     return typeof other == 'object';
    -264   }
    -265 
    -266   return other instanceof this.expectedClass;
    -267 };
    -268 
    -269 jasmine.Matchers.Any.prototype.toString = function() {
    -270   return '<jasmine.any(' + this.expectedClass + ')>';
    -271 };
    -272 
    -273 
    \ No newline at end of file diff --git a/doc/symbols/src/src_NestedResults.js.html b/doc/symbols/src/src_NestedResults.js.html deleted file mode 100644 index 47bc43a..0000000 --- a/doc/symbols/src/src_NestedResults.js.html +++ /dev/null @@ -1,88 +0,0 @@ -
      1 /**
    -  2  * Holds results for a set of Jasmine spec. Allows for the results array to hold another jasmine.NestedResults
    -  3  *
    -  4  * @constructor
    -  5  */
    -  6 jasmine.NestedResults = function() {
    -  7   /**
    -  8    * The total count of results
    -  9    */
    - 10   this.totalCount = 0;
    - 11   /**
    - 12    * Number of passed results
    - 13    */
    - 14   this.passedCount = 0;
    - 15   /**
    - 16    * Number of failed results
    - 17    */
    - 18   this.failedCount = 0;
    - 19   /**
    - 20    * Was this suite/spec skipped?
    - 21    */
    - 22   this.skipped = false;
    - 23   /**
    - 24    * @ignore
    - 25    */
    - 26   this.items_ = [];
    - 27 };
    - 28 
    - 29 /**
    - 30  * Roll up the result counts.
    - 31  *
    - 32  * @param result
    - 33  */
    - 34 jasmine.NestedResults.prototype.rollupCounts = function(result) {
    - 35   this.totalCount += result.totalCount;
    - 36   this.passedCount += result.passedCount;
    - 37   this.failedCount += result.failedCount;
    - 38 };
    - 39 
    - 40 /**
    - 41  * Tracks a result's message.
    - 42  * @param message
    - 43  */
    - 44 jasmine.NestedResults.prototype.log = function(message) {
    - 45   this.items_.push(new jasmine.MessageResult(message));
    - 46 };
    - 47 
    - 48 /**
    - 49  * Getter for the results: message & results.
    - 50  */
    - 51 jasmine.NestedResults.prototype.getItems = function() {
    - 52   return this.items_;
    - 53 };
    - 54 
    - 55 /**
    - 56  * Adds a result, tracking counts (total, passed, & failed)
    - 57  * @param {jasmine.ExpectationResult|jasmine.NestedResults} result
    - 58  */
    - 59 jasmine.NestedResults.prototype.addResult = function(result) {
    - 60   if (result.type != 'MessageResult') {
    - 61     if (result.items_) {
    - 62       this.rollupCounts(result);
    - 63     } else {
    - 64       this.totalCount++;
    - 65       if (result.passed) {
    - 66         this.passedCount++;
    - 67       } else {
    - 68         this.failedCount++;
    - 69       }
    - 70     }
    - 71   }
    - 72   this.items_.push(result);
    - 73 };
    - 74 
    - 75 /**
    - 76  * @returns {Boolean} True if <b>everything</b> below passed
    - 77  */
    - 78 jasmine.NestedResults.prototype.passed = function() {
    - 79   return this.passedCount === this.totalCount;
    - 80 };
    - 81 
    \ No newline at end of file diff --git a/doc/symbols/src/src_PrettyPrinter.js.html b/doc/symbols/src/src_PrettyPrinter.js.html deleted file mode 100644 index da77fcc..0000000 --- a/doc/symbols/src/src_PrettyPrinter.js.html +++ /dev/null @@ -1,123 +0,0 @@ -
      1 /**
    -  2  * Base class for pretty printing for expectation results.
    -  3  */
    -  4 jasmine.PrettyPrinter = function() {
    -  5   this.ppNestLevel_ = 0;
    -  6 };
    -  7 
    -  8 /**
    -  9  * Formats a value in a nice, human-readable string.
    - 10  *
    - 11  * @param value
    - 12  * @returns {String}
    - 13  */
    - 14 jasmine.PrettyPrinter.prototype.format = function(value) {
    - 15   if (this.ppNestLevel_ > 40) {
    - 16     //    return '(jasmine.pp nested too deeply!)';
    - 17     throw new Error('jasmine.PrettyPrinter: format() nested too deeply!');
    - 18   }
    - 19 
    - 20   this.ppNestLevel_++;
    - 21   try {
    - 22     if (value === undefined) {
    - 23       this.emitScalar('undefined');
    - 24     } else if (value === null) {
    - 25       this.emitScalar('null');
    - 26     } else if (value.navigator && value.frames && value.setTimeout) {
    - 27       this.emitScalar('<window>');
    - 28     } else if (value instanceof jasmine.Matchers.Any) {
    - 29       this.emitScalar(value.toString());
    - 30     } else if (typeof value === 'string') {
    - 31       this.emitScalar("'" + value + "'");
    - 32     } else if (typeof value === 'function') {
    - 33       this.emitScalar('Function');
    - 34     } else if (typeof value.nodeType === 'number') {
    - 35       this.emitScalar('HTMLNode');
    - 36     } else if (value instanceof Date) {
    - 37       this.emitScalar('Date(' + value + ')');
    - 38     } else if (value.__Jasmine_been_here_before__) {
    - 39       this.emitScalar('<circular reference: ' + (jasmine.isArray_(value) ? 'Array' : 'Object') + '>');
    - 40     } else if (jasmine.isArray_(value) || typeof value == 'object') {
    - 41       value.__Jasmine_been_here_before__ = true;
    - 42       if (jasmine.isArray_(value)) {
    - 43         this.emitArray(value);
    - 44       } else {
    - 45         this.emitObject(value);
    - 46       }
    - 47       delete value.__Jasmine_been_here_before__;
    - 48     } else {
    - 49       this.emitScalar(value.toString());
    - 50     }
    - 51   } finally {
    - 52     this.ppNestLevel_--;
    - 53   }
    - 54 };
    - 55 
    - 56 jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
    - 57   for (var property in obj) {
    - 58     if (property == '__Jasmine_been_here_before__') continue;
    - 59     fn(property, obj.__lookupGetter__(property) != null);
    - 60   }
    - 61 };
    - 62 
    - 63 jasmine.PrettyPrinter.prototype.emitArray = jasmine.unimplementedMethod_;
    - 64 jasmine.PrettyPrinter.prototype.emitObject = jasmine.unimplementedMethod_;
    - 65 jasmine.PrettyPrinter.prototype.emitScalar = jasmine.unimplementedMethod_;
    - 66 
    - 67 jasmine.StringPrettyPrinter = function() {
    - 68   jasmine.PrettyPrinter.call(this);
    - 69 
    - 70   this.string = '';
    - 71 };
    - 72 jasmine.util.inherit(jasmine.StringPrettyPrinter, jasmine.PrettyPrinter);
    - 73 
    - 74 jasmine.StringPrettyPrinter.prototype.emitScalar = function(value) {
    - 75   this.append(value);
    - 76 };
    - 77 
    - 78 jasmine.StringPrettyPrinter.prototype.emitArray = function(array) {
    - 79   this.append('[ ');
    - 80   for (var i = 0; i < array.length; i++) {
    - 81     if (i > 0) {
    - 82       this.append(', ');
    - 83     }
    - 84     this.format(array[i]);
    - 85   }
    - 86   this.append(' ]');
    - 87 };
    - 88 
    - 89 jasmine.StringPrettyPrinter.prototype.emitObject = function(obj) {
    - 90   var self = this;
    - 91   this.append('{ ');
    - 92   var first = true;
    - 93 
    - 94   this.iterateObject(obj, function(property, isGetter) {
    - 95     if (first) {
    - 96       first = false;
    - 97     } else {
    - 98       self.append(', ');
    - 99     }
    -100 
    -101     self.append(property);
    -102     self.append(' : ');
    -103     if (isGetter) {
    -104       self.append('<getter>');
    -105     } else {
    -106       self.format(obj[property]);
    -107     }
    -108   });
    -109 
    -110   this.append(' }');
    -111 };
    -112 
    -113 jasmine.StringPrettyPrinter.prototype.append = function(value) {
    -114   this.string += value;
    -115 };
    -116 
    \ No newline at end of file diff --git a/doc/symbols/src/src_QueuedFunction.js.html b/doc/symbols/src/src_QueuedFunction.js.html deleted file mode 100644 index c3642a3..0000000 --- a/doc/symbols/src/src_QueuedFunction.js.html +++ /dev/null @@ -1,94 +0,0 @@ -
      1 /**
    -  2  * QueuedFunction is how ActionCollections' actions are implemented
    -  3  *
    -  4  * @constructor
    -  5  * @param {jasmine.Env} env
    -  6  * @param {Function} func
    -  7  * @param {Number} timeout
    -  8  * @param {Function} latchFunction
    -  9  * @param {jasmine.Spec} spec
    - 10  */
    - 11 jasmine.QueuedFunction = function(env, func, timeout, latchFunction, spec) {
    - 12   this.env = env;
    - 13   this.func = func;
    - 14   this.timeout = timeout;
    - 15   this.latchFunction = latchFunction;
    - 16   this.spec = spec;
    - 17 
    - 18   this.totalTimeSpentWaitingForLatch = 0;
    - 19   this.latchTimeoutIncrement = 100;
    - 20 };
    - 21 
    - 22 jasmine.QueuedFunction.prototype.next = function() {
    - 23   this.spec.finish(); // default value is to be done after one function
    - 24 };
    - 25 
    - 26 jasmine.QueuedFunction.prototype.safeExecute = function() {
    - 27   if (this.env.reporter) {
    - 28     this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...');
    - 29   }
    - 30 
    - 31   try {
    - 32     this.func.apply(this.spec);
    - 33   } catch (e) {
    - 34     this.fail(e);
    - 35   }
    - 36 };
    - 37 
    - 38 jasmine.QueuedFunction.prototype.execute = function() {
    - 39   var self = this;
    - 40   var executeNow = function() {
    - 41     self.safeExecute();
    - 42     self.next();
    - 43   };
    - 44 
    - 45   var executeLater = function() {
    - 46     self.env.setTimeout(executeNow, self.timeout);
    - 47   };
    - 48 
    - 49   var executeNowOrLater = function() {
    - 50     var latchFunctionResult;
    - 51 
    - 52     try {
    - 53       latchFunctionResult = self.latchFunction.apply(self.spec);
    - 54     } catch (e) {
    - 55       self.fail(e);
    - 56       self.next();
    - 57       return;
    - 58     }
    - 59 
    - 60     if (latchFunctionResult) {
    - 61       executeNow();
    - 62     } else if (self.totalTimeSpentWaitingForLatch >= self.timeout) {
    - 63       var message = 'timed out after ' + self.timeout + ' msec waiting for ' + (self.latchFunction.description || 'something to happen');
    - 64       self.fail({
    - 65         name: 'timeout',
    - 66         message: message
    - 67       });
    - 68       self.next();
    - 69     } else {
    - 70       self.totalTimeSpentWaitingForLatch += self.latchTimeoutIncrement;
    - 71       self.env.setTimeout(executeNowOrLater, self.latchTimeoutIncrement);
    - 72     }
    - 73   };
    - 74 
    - 75   if (this.latchFunction !== undefined) {
    - 76     executeNowOrLater();
    - 77   } else if (this.timeout > 0) {
    - 78     executeLater();
    - 79   } else {
    - 80     executeNow();
    - 81   }
    - 82 };
    - 83 
    - 84 jasmine.QueuedFunction.prototype.fail = function(e) {
    - 85   this.spec.results.addResult(new jasmine.ExpectationResult(false, jasmine.util.formatException(e), null));
    - 86 };
    - 87 
    \ No newline at end of file diff --git a/doc/symbols/src/src_Reporters.js.html b/doc/symbols/src/src_Reporters.js.html deleted file mode 100644 index 996a8e2..0000000 --- a/doc/symbols/src/src_Reporters.js.html +++ /dev/null @@ -1,41 +0,0 @@ -
      1 /* JasmineReporters.reporter
    -  2  *    Base object that will get called whenever a Spec, Suite, or Runner is done.  It is up to
    -  3  *    descendants of this object to do something with the results (see json_reporter.js)
    -  4  */
    -  5 jasmine.Reporters = {};
    -  6 
    -  7 jasmine.Reporters.reporter = function(callbacks) {
    -  8   var that = {
    -  9     callbacks: callbacks || {},
    - 10 
    - 11     doCallback: function(callback, results) {
    - 12       if (callback) {
    - 13         callback(results);
    - 14       }
    - 15     },
    - 16 
    - 17     reportRunnerResults: function(runner) {
    - 18       that.doCallback(that.callbacks.runnerCallback, runner);
    - 19     },
    - 20     reportSuiteResults:  function(suite) {
    - 21       that.doCallback(that.callbacks.suiteCallback, suite);
    - 22     },
    - 23     reportSpecResults:   function(spec) {
    - 24       that.doCallback(that.callbacks.specCallback, spec);
    - 25     },
    - 26     log: function (str) {
    - 27       if (console && console.log) console.log(str);
    - 28     }
    - 29   };
    - 30 
    - 31   return that;
    - 32 };
    - 33 
    - 34 
    \ No newline at end of file diff --git a/doc/symbols/src/src_Runner.js.html b/doc/symbols/src/src_Runner.js.html deleted file mode 100644 index 2b828fa..0000000 --- a/doc/symbols/src/src_Runner.js.html +++ /dev/null @@ -1,34 +0,0 @@ -
      1 /**
    -  2  * Runner
    -  3  *
    -  4  * @constructor
    -  5  * @param {jasmine.Env} env
    -  6  */
    -  7 jasmine.Runner = function(env) {
    -  8   jasmine.ActionCollection.call(this, env);
    -  9 
    - 10   this.suites = this.actions;
    - 11 };
    - 12 jasmine.util.inherit(jasmine.Runner, jasmine.ActionCollection);
    - 13 
    - 14 jasmine.Runner.prototype.finishCallback = function() {
    - 15   if (this.env.reporter) {
    - 16     this.env.reporter.reportRunnerResults(this);
    - 17   }
    - 18 };
    - 19 
    - 20 jasmine.Runner.prototype.getResults = function() {
    - 21   var results = new jasmine.NestedResults();
    - 22   for (var i = 0; i < this.suites.length; i++) {
    - 23     results.rollupCounts(this.suites[i].getResults());
    - 24   }
    - 25   return results;
    - 26 };
    - 27 
    \ No newline at end of file diff --git a/doc/symbols/src/src_Spec.js.html b/doc/symbols/src/src_Spec.js.html deleted file mode 100644 index e75c5ad..0000000 --- a/doc/symbols/src/src_Spec.js.html +++ /dev/null @@ -1,199 +0,0 @@ -
      1 /**
    -  2  * Internal representation of a Jasmine specification, or test.
    -  3  * @private
    -  4  * @constructs
    -  5  * @param {jasmine.Env} env
    -  6  * @param {jasmine.Suite} suite
    -  7  * @param {String} description
    -  8  */
    -  9 jasmine.Spec = function(env, suite, description) {
    - 10   this.id = env.nextSpecId_++;
    - 11   this.env = env;
    - 12   this.suite = suite;
    - 13   this.description = description;
    - 14   this.queue = [];
    - 15   this.currentTimeout = 0;
    - 16   this.currentLatchFunction = undefined;
    - 17   this.finished = false;
    - 18   this.afterCallbacks = [];
    - 19   this.spies_ = [];
    - 20 
    - 21   this.results = new jasmine.NestedResults();
    - 22   this.results.description = description;
    - 23   this.runs = this.addToQueue;
    - 24 };
    - 25 
    - 26 jasmine.Spec.prototype.getFullName = function() {
    - 27   return this.suite.getFullName() + ' ' + this.description + '.';
    - 28 };
    - 29 
    - 30 jasmine.Spec.prototype.getResults = function() {
    - 31   return this.results;
    - 32 };
    - 33 
    - 34 jasmine.Spec.prototype.addToQueue = function(func) {
    - 35   var queuedFunction = new jasmine.QueuedFunction(this.env, func, this.currentTimeout, this.currentLatchFunction, this);
    - 36   this.queue.push(queuedFunction);
    - 37 
    - 38   if (this.queue.length > 1) {
    - 39     var previousQueuedFunction = this.queue[this.queue.length - 2];
    - 40     previousQueuedFunction.next = function() {
    - 41       queuedFunction.execute();
    - 42     };
    - 43   }
    - 44 
    - 45   this.resetTimeout();
    - 46   return this;
    - 47 };
    - 48 
    - 49 /**
    - 50  * @private
    - 51  * @deprecated
    - 52  */
    - 53 jasmine.Spec.prototype.expects_that = function(actual) {
    - 54   return this.expect(actual);
    - 55 };
    - 56 
    - 57 /**
    - 58  * @private
    - 59  * @deprecated
    - 60  */
    - 61 jasmine.Spec.prototype.expect = function(actual) {
    - 62   return new jasmine.Matchers(this.env, actual, this.results);
    - 63 };
    - 64 
    - 65 /**
    - 66  * @private
    - 67  * @deprecated
    - 68  */
    - 69 jasmine.Spec.prototype.waits = function(timeout) {
    - 70   this.currentTimeout = timeout;
    - 71   this.currentLatchFunction = undefined;
    - 72   return this;
    - 73 };
    - 74 
    - 75 /**
    - 76  * @private
    - 77  * @deprecated
    - 78  */
    - 79 jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, message) {
    - 80   this.currentTimeout = timeout;
    - 81   this.currentLatchFunction = latchFunction;
    - 82   this.currentLatchFunction.description = message;
    - 83   return this;
    - 84 };
    - 85 
    - 86 jasmine.Spec.prototype.resetTimeout = function() {
    - 87   this.currentTimeout = 0;
    - 88   this.currentLatchFunction = undefined;
    - 89 };
    - 90 
    - 91 jasmine.Spec.prototype.finishCallback = function() {
    - 92   if (this.env.reporter) {
    - 93     this.env.reporter.reportSpecResults(this);
    - 94   }
    - 95 };
    - 96 
    - 97 jasmine.Spec.prototype.finish = function() {
    - 98   this.safeExecuteAfters();
    - 99 
    -100   this.removeAllSpies();
    -101   this.finishCallback();
    -102   this.finished = true;
    -103 };
    -104 
    -105 jasmine.Spec.prototype.after = function(doAfter) {
    -106   this.afterCallbacks.unshift(doAfter);
    -107 };
    -108 
    -109 jasmine.Spec.prototype.execute = function() {
    -110   if (!this.env.specFilter(this)) {
    -111     this.results.skipped = true;
    -112     this.finishCallback();
    -113     this.finished = true;
    -114     return;
    -115   }
    -116 
    -117   this.env.currentSpec = this;
    -118   this.env.currentlyRunningTests = true;
    -119 
    -120   this.safeExecuteBefores();
    -121 
    -122   if (this.queue[0]) {
    -123     this.queue[0].execute();
    -124   } else {
    -125     this.finish();
    -126   }
    -127   this.env.currentlyRunningTests = false;
    -128 };
    -129 
    -130 jasmine.Spec.prototype.safeExecuteBefores = function() {
    -131   var befores = [];
    -132   for (var suite = this.suite; suite; suite = suite.parentSuite) {
    -133     if (suite.beforeEachFunction) befores.push(suite.beforeEachFunction);
    -134   }
    -135 
    -136   while (befores.length) {
    -137     this.safeExecuteBeforeOrAfter(befores.pop());
    -138   }
    -139 };
    -140 
    -141 jasmine.Spec.prototype.safeExecuteAfters = function() {
    -142   for (var suite = this.suite; suite; suite = suite.parentSuite) {
    -143     if (suite.afterEachFunction) this.safeExecuteBeforeOrAfter(suite.afterEachFunction);
    -144   }
    -145 };
    -146 
    -147 jasmine.Spec.prototype.safeExecuteBeforeOrAfter = function(func) {
    -148   try {
    -149     func.apply(this);
    -150   } catch (e) {
    -151     this.results.addResult(new jasmine.ExpectationResult(false, func.typeName + '() fail: ' + jasmine.util.formatException(e), null));
    -152   }
    -153 };
    -154 
    -155 jasmine.Spec.prototype.explodes = function() {
    -156   throw 'explodes function should not have been called';
    -157 };
    -158 
    -159 jasmine.Spec.prototype.spyOn = function(obj, methodName, ignoreMethodDoesntExist) {
    -160   if (obj == undefined) {
    -161     throw "spyOn could not find an object to spy upon for " + methodName + "()";
    -162   }
    -163 
    -164   if (!ignoreMethodDoesntExist && obj[methodName] === undefined) {
    -165     throw methodName + '() method does not exist';
    -166   }
    -167 
    -168   if (!ignoreMethodDoesntExist && obj[methodName] && obj[methodName].isSpy) {
    -169     throw new Error(methodName + ' has already been spied upon');
    -170   }
    -171 
    -172   var spyObj = jasmine.createSpy(methodName);
    -173 
    -174   this.spies_.push(spyObj);
    -175   spyObj.baseObj = obj;
    -176   spyObj.methodName = methodName;
    -177   spyObj.originalValue = obj[methodName];
    -178 
    -179   obj[methodName] = spyObj;
    -180 
    -181   return spyObj;
    -182 };
    -183 
    -184 jasmine.Spec.prototype.removeAllSpies = function() {
    -185   for (var i = 0; i < this.spies_.length; i++) {
    -186     var spy = this.spies_[i];
    -187     spy.baseObj[spy.methodName] = spy.originalValue;
    -188   }
    -189   this.spies_ = [];
    -190 };
    -191 
    -192 
    \ No newline at end of file diff --git a/doc/symbols/src/src_Suite.js.html b/doc/symbols/src/src_Suite.js.html deleted file mode 100644 index 9157f41..0000000 --- a/doc/symbols/src/src_Suite.js.html +++ /dev/null @@ -1,61 +0,0 @@ -
      1 /**
    -  2  * For storing & executing a Jasmine suite.
    -  3  *
    -  4  * @constructor
    -  5  * @param {jasmine.Env} env
    -  6  * @param {String} description
    -  7  * @param {Function} specDefinitions
    -  8  * @param {jasmine.Suite} parentSuite
    -  9  */
    - 10 jasmine.Suite = function(env, description, specDefinitions, parentSuite) {
    - 11   jasmine.ActionCollection.call(this, env);
    - 12 
    - 13   this.description = description;
    - 14   this.specs = this.actions;
    - 15   this.parentSuite = parentSuite;
    - 16 
    - 17   this.beforeEachFunction = null;
    - 18   this.afterEachFunction = null;
    - 19 };
    - 20 jasmine.util.inherit(jasmine.Suite, jasmine.ActionCollection);
    - 21 
    - 22 jasmine.Suite.prototype.getFullName = function() {
    - 23   var fullName = this.description;
    - 24   for (var parentSuite = this.parentSuite; parentSuite; parentSuite = parentSuite.parentSuite) {
    - 25     fullName = parentSuite.description + ' ' + fullName;
    - 26   }
    - 27   return fullName;
    - 28 };
    - 29 
    - 30 jasmine.Suite.prototype.finishCallback = function() {
    - 31   if (this.env.reporter) {
    - 32     this.env.reporter.reportSuiteResults(this);
    - 33   }
    - 34 };
    - 35 
    - 36 jasmine.Suite.prototype.beforeEach = function(beforeEachFunction) {
    - 37   beforeEachFunction.typeName = 'beforeEach';
    - 38   this.beforeEachFunction = beforeEachFunction;
    - 39 };
    - 40 
    - 41 jasmine.Suite.prototype.afterEach = function(afterEachFunction) {
    - 42   afterEachFunction.typeName = 'afterEach';
    - 43   this.afterEachFunction = afterEachFunction;
    - 44 };
    - 45 
    - 46 jasmine.Suite.prototype.getResults = function() {
    - 47   var results = new jasmine.NestedResults();
    - 48   for (var i = 0; i < this.specs.length; i++) {
    - 49     results.rollupCounts(this.specs[i].getResults());
    - 50   }
    - 51   return results;
    - 52 };
    - 53 
    - 54 
    \ No newline at end of file diff --git a/doc/symbols/src/src_base.js.html b/doc/symbols/src/src_base.js.html deleted file mode 100644 index db29192..0000000 --- a/doc/symbols/src/src_base.js.html +++ /dev/null @@ -1,517 +0,0 @@ -
      1 /**
    -  2  * Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
    -  3  * 
    -  4  * @namespace
    -  5  */
    -  6 var jasmine = {};
    -  7 
    -  8 /**
    -  9  * @private
    - 10  */
    - 11 jasmine.unimplementedMethod_ = function() {
    - 12   throw new Error("unimplemented method");
    - 13 };
    - 14 
    - 15 /**
    - 16  * Allows for bound functions to be comapred.  Internal use only.
    - 17  *
    - 18  * @ignore
    - 19  * @private
    - 20  * @param base {Object} bound 'this' for the function
    - 21  * @param name {Function} function to find
    - 22  */
    - 23 jasmine.bindOriginal_ = function(base, name) {
    - 24   var original = base[name];
    - 25   return function() {
    - 26     return original.apply(base, arguments);
    - 27   };
    - 28 };
    - 29 
    - 30 jasmine.setTimeout = jasmine.bindOriginal_(window, 'setTimeout');
    - 31 jasmine.clearTimeout = jasmine.bindOriginal_(window, 'clearTimeout');
    - 32 jasmine.setInterval = jasmine.bindOriginal_(window, 'setInterval');
    - 33 jasmine.clearInterval = jasmine.bindOriginal_(window, 'clearInterval');
    - 34 
    - 35 jasmine.MessageResult = function(text) {
    - 36   this.type = 'MessageResult';
    - 37   this.text = text;
    - 38   this.trace = new Error(); // todo: test better
    - 39 };
    - 40 
    - 41 jasmine.ExpectationResult = function(passed, message, details) {
    - 42   this.type = 'ExpectationResult';
    - 43   this.passed = passed;
    - 44   this.message = message;
    - 45   this.details = details;
    - 46   this.trace = new Error(message); // todo: test better
    - 47 };
    - 48 
    - 49 /**
    - 50  * Getter for the Jasmine environment. Ensures one gets created
    - 51  */
    - 52 jasmine.getEnv = function() {
    - 53   return jasmine.currentEnv_ = jasmine.currentEnv_ || new jasmine.Env();
    - 54 };
    - 55 
    - 56 /**
    - 57  * @ignore
    - 58  * @private
    - 59  * @param value
    - 60  * @returns {Boolean}
    - 61  */
    - 62 jasmine.isArray_ = function(value) {
    - 63   return value &&
    - 64   typeof value === 'object' &&
    - 65   typeof value.length === 'number' &&
    - 66   typeof value.splice === 'function' &&
    - 67   !(value.propertyIsEnumerable('length'));
    - 68 };
    - 69 
    - 70 /**
    - 71  * Pretty printer for expecations.  Takes any object and turns it into a human-readable string.
    - 72  *
    - 73  * @param value {Object} an object to be outputted
    - 74  * @returns {String}
    - 75  */
    - 76 jasmine.pp = function(value) {
    - 77   var stringPrettyPrinter = new jasmine.StringPrettyPrinter();
    - 78   stringPrettyPrinter.format(value);
    - 79   return stringPrettyPrinter.string;
    - 80 };
    - 81 
    - 82 /**
    - 83  * Returns true if the object is a DOM Node.
    - 84  *
    - 85  * @param {Object} obj object to check
    - 86  * @returns {Boolean}
    - 87  */
    - 88 jasmine.isDomNode = function(obj) {
    - 89   return obj['nodeType'] > 0;
    - 90 };
    - 91 
    - 92 /**
    - 93  * Returns a matchable 'generic' object of the class type.  For use in expecations of type when values don't matter.
    - 94  *
    - 95  * @example
    - 96  * // don't care about which function is passed in, as long as it's a function
    - 97  * expect(mySpy).wasCalledWith(jasmine.any(Function));
    - 98  *
    - 99  * @param {Class} clazz
    -100  * @returns matchable object of the type clazz
    -101  */
    -102 jasmine.any = function(clazz) {
    -103   return new jasmine.Matchers.Any(clazz);
    -104 };
    -105 
    -106 /**
    -107  * Jasmine Spies are test doubles that can act as stubs, spies, fakes or when used in an expecation, mocks.
    -108  *
    -109  * Spies should be created in test setup, before expectations.  They can then be checked, using the standard Jasmine
    -110  * expectation syntax. Spies can be checked if they were called or not and what the calling params were.
    -111  *
    -112  * A Spy has the following mehtod: wasCalled, callCount, mostRecentCall, and argsForCall (see docs)
    -113  * Spies are torn down at the end of every spec.
    -114  *
    -115  * Note: Do <b>not</b> call new jasmine.Spy() directly - a spy must be created using spyOn, jasmine.createSpy or jasmine.createSpyObj.
    -116  * 
    -117  * @example
    -118  * // a stub
    -119  * var myStub = jasmine.createSpy('myStub');  // can be used anywhere
    -120  *
    -121  * // spy example
    -122  * var foo = {
    -123  *   not: function(bool) { return !bool; }
    -124  * }
    -125  *
    -126  * // actual foo.not will not be called, execution stops
    -127  * spyOn(foo, 'not');
    -128 
    -129  // foo.not spied upon, execution will continue to implementation
    -130  * spyOn(foo, 'not').andCallThrough();
    -131  *
    -132  * // fake example
    -133  * var foo = {
    -134  *   not: function(bool) { return !bool; }
    -135  * }
    -136  *
    -137  * // foo.not(val) will return val
    -138  * spyOn(foo, 'not').andCallFake(function(value) {return value;});
    -139  *
    -140  * // mock example
    -141  * foo.not(7 == 7);
    -142  * expect(foo.not).wasCalled();
    -143  * expect(foo.not).wasCalledWith(true);
    -144  *
    -145  * @constructor
    -146  * @see spyOn, jasmine.createSpy, jasmine.createSpyObj
    -147  * @param {String} name
    -148  */
    -149 jasmine.Spy = function(name) {
    -150   /**
    -151    * The name of the spy, if provided.
    -152    */
    -153   this.identity = name || 'unknown';
    -154   /**
    -155    *  Is this Object a spy?
    -156    */
    -157   this.isSpy = true;
    -158   /**
    -159    * The acutal function this spy stubs.
    -160    */
    -161   this.plan = function() {};
    -162   /**
    -163    * Tracking of the most recent call to the spy.
    -164    * @example
    -165    * var mySpy = jasmine.createSpy('foo');
    -166    * mySpy(1, 2);
    -167    * mySpy.mostRecentCall.args = [1, 2];
    -168    */
    -169   this.mostRecentCall = {};
    -170 
    -171   /**
    -172    * Holds arguments for each call to the spy, indexed by call count
    -173    * @example
    -174    * var mySpy = jasmine.createSpy('foo');
    -175    * mySpy(1, 2);
    -176    * mySpy(7, 8);
    -177    * mySpy.mostRecentCall.args = [7, 8];
    -178    * mySpy.argsForCall[0] = [1, 2];
    -179    * mySpy.argsForCall[1] = [7, 8];
    -180    */
    -181   this.argsForCall = [];
    -182 };
    -183 
    -184 /**
    -185  * Tells a spy to call through to the actual implemenatation.
    -186  *
    -187  * @example
    -188  * var foo = {
    -189  *   bar: function() { // do some stuff }
    -190  * }
    -191  * 
    -192  * // defining a spy on an existing property: foo.bar
    -193  * spyOn(foo, 'bar').andCallThrough();
    -194  */
    -195 jasmine.Spy.prototype.andCallThrough = function() {
    -196   this.plan = this.originalValue;
    -197   return this;
    -198 };
    -199 
    -200 /**
    -201  * For setting the return value of a spy.
    -202  *
    -203  * @example
    -204  * // defining a spy from scratch: foo() returns 'baz'
    -205  * var foo = jasmine.createSpy('spy on foo').andReturn('baz');
    -206  *
    -207  * // defining a spy on an existing property: foo.bar() returns 'baz'
    -208  * spyOn(foo, 'bar').andReturn('baz');
    -209  *
    -210  * @param {Object} value
    -211  */
    -212 jasmine.Spy.prototype.andReturn = function(value) {
    -213   this.plan = function() {
    -214     return value;
    -215   };
    -216   return this;
    -217 };
    -218 
    -219 /**
    -220  * For throwing an exception when a spy is called.
    -221  *
    -222  * @example
    -223  * // defining a spy from scratch: foo() throws an exception w/ message 'ouch'
    -224  * var foo = jasmine.createSpy('spy on foo').andThrow('baz');
    -225  *
    -226  * // defining a spy on an existing property: foo.bar() throws an exception w/ message 'ouch'
    -227  * spyOn(foo, 'bar').andThrow('baz');
    -228  *
    -229  * @param {String} exceptionMsg
    -230  */
    -231 jasmine.Spy.prototype.andThrow = function(exceptionMsg) {
    -232   this.plan = function() {
    -233     throw exceptionMsg;
    -234   };
    -235   return this;
    -236 };
    -237 
    -238 /**
    -239  * Calls an alternate implementation when a spy is called.
    -240  *
    -241  * @example
    -242  * var baz = function() {
    -243  *   // do some stuff, return something
    -244  * }
    -245  * // defining a spy from scratch: foo() calls the function baz
    -246  * var foo = jasmine.createSpy('spy on foo').andCall(baz);
    -247  *
    -248  * // defining a spy on an existing property: foo.bar() calls an anonymnous function
    -249  * spyOn(foo, 'bar').andCall(function() { return 'baz';} );
    -250  *
    -251  * @param {Function} fakeFunc
    -252  */
    -253 jasmine.Spy.prototype.andCallFake = function(fakeFunc) {
    -254   this.plan = fakeFunc;
    -255   return this;
    -256 };
    -257 
    -258 /**
    -259  * Resets all of a spy's the tracking variables so that it can be used again.
    -260  *
    -261  * @example
    -262  * spyOn(foo, 'bar');
    -263  *
    -264  * foo.bar();
    -265  *
    -266  * expect(foo.bar.callCount).toEqual(1);
    -267  *
    -268  * foo.bar.reset();
    -269  *
    -270  * expect(foo.bar.callCount).toEqual(0);
    -271  */
    -272 jasmine.Spy.prototype.reset = function() {
    -273   this.wasCalled = false;
    -274   this.callCount = 0;
    -275   this.argsForCall = [];
    -276   this.mostRecentCall = {};
    -277 };
    -278 
    -279 jasmine.createSpy = function(name) {
    -280 
    -281   var spyObj = function() {
    -282     spyObj.wasCalled = true;
    -283     spyObj.callCount++;
    -284     var args = jasmine.util.argsToArray(arguments);
    -285     //spyObj.mostRecentCall = {
    -286     //  object: this,
    -287     //  args: args
    -288     //};
    -289     spyObj.mostRecentCall.object = this;
    -290     spyObj.mostRecentCall.args = args;
    -291     spyObj.argsForCall.push(args);
    -292     return spyObj.plan.apply(this, arguments);
    -293   };
    -294 
    -295   var spy = new jasmine.Spy(name);
    -296   
    -297   for(var prop in spy) {
    -298     spyObj[prop] = spy[prop];
    -299   }
    -300   
    -301   spyObj.reset();
    -302 
    -303   return spyObj;
    -304 };
    -305 
    -306 /**
    -307  * Creates a more complicated spy: an Object that has every property a function that is a spy.  Used for stubbing something
    -308  * large in one call.
    -309  *
    -310  * @param {String} baseName name of spy class
    -311  * @param {Array} methodNames array of names of methods to make spies
    -312  */
    -313 jasmine.createSpyObj = function(baseName, methodNames) {
    -314   var obj = {};
    -315   for (var i = 0; i < methodNames.length; i++) {
    -316     obj[methodNames[i]] = jasmine.createSpy(baseName + '.' + methodNames[i]);
    -317   }
    -318   return obj;
    -319 };
    -320 
    -321 jasmine.log = function(message) {
    -322   jasmine.getEnv().currentSpec.getResults().log(message);
    -323 };
    -324 
    -325 /**
    -326  * Function that installs a spy on an existing object's method name.  Used within a Spec to create a spy.
    -327  *
    -328  * @example
    -329  * // spy example
    -330  * var foo = {
    -331  *   not: function(bool) { return !bool; }
    -332  * }
    -333  * spyOn(foo, 'not'); // actual foo.not will not be called, execution stops
    -334  *
    -335  * @see jasmine.createSpy
    -336  * @param obj
    -337  * @param methodName
    -338  * @returns a Jasmine spy that can be chained with all spy methods
    -339  */
    -340 var spyOn = function(obj, methodName) {
    -341   return jasmine.getEnv().currentSpec.spyOn(obj, methodName);
    -342 };
    -343 
    -344 /**
    -345  * Creates a Jasmine spec that will be added to the current suite.
    -346  *
    -347  * // TODO: pending tests
    -348  *
    -349  * @example
    -350  * it('should be true', function() {
    -351  *   expect(true).toEqual(true);
    -352  * });
    -353  *
    -354  * @param {String} desc description of this specification
    -355  * @param {Function} func defines the preconditions and expectations of the spec
    -356  */
    -357 var it = function(desc, func) {
    -358   return jasmine.getEnv().it(desc, func);
    -359 };
    -360 
    -361 /**
    -362  * Creates a <em>disabled</em> Jasmine spec.
    -363  *
    -364  * A convenience method that allows existing specs to be disabled temporarily during development.
    -365  *
    -366  * @param {String} desc description of this specification
    -367  * @param {Function} func defines the preconditions and expectations of the spec
    -368  */
    -369 var xit = function(desc, func) {
    -370   return jasmine.getEnv().xit(desc, func);
    -371 };
    -372 
    -373 /**
    -374  * Starts a chain for a Jasmine expectation.
    -375  *
    -376  * It is passed an Object that is the actual value and should chain to one of the many
    -377  * jasmine.Matchers functions.
    -378  *
    -379  * @param {Object} actual Actual value to test against and expected value
    -380  */
    -381 var expect = function(actual) {
    -382   return jasmine.getEnv().currentSpec.expect(actual);
    -383 };
    -384 
    -385 /**
    -386  * Defines part of a jasmine spec.  Used in cominbination with waits or waitsFor in asynchrnous specs.
    -387  *
    -388  * @param {Function} func Function that defines part of a jasmine spec.
    -389  */
    -390 var runs = function(func) {
    -391   jasmine.getEnv().currentSpec.runs(func);
    -392 };
    -393 
    -394 /**
    -395  * Waits for a timeout before moving to the next runs()-defined block.
    -396  * @param {Number} timeout
    -397  */
    -398 var waits = function(timeout) {
    -399   jasmine.getEnv().currentSpec.waits(timeout);
    -400 };
    -401 
    -402 /**
    -403  * Waits for the latchFunction to return true before proceeding to the next runs()-defined block.
    -404  *  
    -405  * @param {Number} timeout
    -406  * @param {Function} latchFunction
    -407  * @param {String} message
    -408  */
    -409 var waitsFor = function(timeout, latchFunction, message) {
    -410   jasmine.getEnv().currentSpec.waitsFor(timeout, latchFunction, message);
    -411 };
    -412 
    -413 /**
    -414  * A function that is called before each spec in a suite.
    -415  *
    -416  * Used for spec setup, including validating assumptions.
    -417  *
    -418  * @param {Function} beforeEachFunction
    -419  */
    -420 var beforeEach = function(beforeEachFunction) {
    -421   jasmine.getEnv().beforeEach(beforeEachFunction);
    -422 };
    -423 
    -424 /**
    -425  * A function that is called after each spec in a suite.
    -426  *
    -427  * Used for restoring any state that is hijacked during spec execution.
    -428  *
    -429  * @param {Function} afterEachFunction
    -430  */
    -431 var afterEach = function(afterEachFunction) {
    -432   jasmine.getEnv().afterEach(afterEachFunction);
    -433 };
    -434 
    -435 /**
    -436  * Defines a suite of specifications.
    -437  *
    -438  * Stores the description and all defined specs in the Jasmine environment as one suite of specs. Variables declared
    -439  * are accessible by calls to beforeEach, it, and afterEach. Describe blocks can be nested, allowing for specialization
    -440  * of setup in some tests.
    -441  *
    -442  * @example
    -443  * // TODO: a simple suite
    -444  *
    -445  * // TODO: a simple suite with a nested describe block
    -446  *
    -447  * @param {String} description A string, usually the class under test.
    -448  * @param {Function} specDefinitions function that defines several specs.
    -449  */
    -450 var describe = function(description, specDefinitions) {
    -451   return jasmine.getEnv().describe(description, specDefinitions);
    -452 };
    -453 
    -454 /**
    -455  * Disables a suite of specifications.  Used to disable some suites in a file, or files, temporarily during development.
    -456  *
    -457  * @param {String} description A string, usually the class under test.
    -458  * @param {Function} specDefinitions function that defines several specs.
    -459  */
    -460 var xdescribe = function(description, specDefinitions) {
    -461   return jasmine.getEnv().xdescribe(description, specDefinitions);
    -462 };
    -463 
    -464 
    -465 jasmine.XmlHttpRequest = XMLHttpRequest;
    -466 
    -467 // Provide the XMLHttpRequest class for IE 5.x-6.x:
    -468 if (typeof XMLHttpRequest == "undefined") jasmine.XmlHttpRequest = function() {
    -469   try {
    -470     return new ActiveXObject("Msxml2.XMLHTTP.6.0");
    -471   } catch(e) {
    -472   }
    -473   try {
    -474     return new ActiveXObject("Msxml2.XMLHTTP.3.0");
    -475   } catch(e) {
    -476   }
    -477   try {
    -478     return new ActiveXObject("Msxml2.XMLHTTP");
    -479   } catch(e) {
    -480   }
    -481   try {
    -482     return new ActiveXObject("Microsoft.XMLHTTP");
    -483   } catch(e) {
    -484   }
    -485   throw new Error("This browser does not support XMLHttpRequest.");
    -486 };
    -487 
    -488 /**
    -489  * Adds suite files to an HTML document so that they are executed, thus adding them to the current
    -490  * Jasmine environment.
    -491  *
    -492  * @param {String} url path to the file to include
    -493  * @param {Boolean} opt_global
    -494  */
    -495 jasmine.include = function(url, opt_global) {
    -496   if (opt_global) {
    -497     document.write('<script type="text/javascript" src="' + url + '"></' + 'script>');
    -498   } else {
    -499     var xhr;
    -500     try {
    -501       xhr = new jasmine.XmlHttpRequest();
    -502       xhr.open("GET", url, false);
    -503       xhr.send(null);
    -504     } catch(e) {
    -505       throw new Error("couldn't fetch " + url + ": " + e);
    -506     }
    -507 
    -508     return eval(xhr.responseText);
    -509   }
    -510 };
    \ No newline at end of file diff --git a/doc/symbols/src/src_jsUnitMockTimeout.js.html b/doc/symbols/src/src_jsUnitMockTimeout.js.html deleted file mode 100644 index 0dd3928..0000000 --- a/doc/symbols/src/src_jsUnitMockTimeout.js.html +++ /dev/null @@ -1,89 +0,0 @@ -
      1 // Mock setTimeout, clearTimeout
    -  2 // Contributed by Pivotal Computer Systems, www.pivotalsf.com
    -  3 
    -  4 var Clock = {
    -  5     timeoutsMade: 0,
    -  6     scheduledFunctions: {},
    -  7     nowMillis: 0,
    -  8     reset: function() {
    -  9         this.scheduledFunctions = {};
    - 10         this.nowMillis = 0;
    - 11         this.timeoutsMade = 0;
    - 12     },
    - 13     tick: function(millis) {
    - 14         var oldMillis = this.nowMillis;
    - 15         var newMillis = oldMillis + millis;
    - 16         this.runFunctionsWithinRange(oldMillis, newMillis);
    - 17         this.nowMillis = newMillis;
    - 18     },
    - 19     runFunctionsWithinRange: function(oldMillis, nowMillis) {
    - 20         var scheduledFunc;
    - 21         var funcsToRun = [];
    - 22         for (var timeoutKey in this.scheduledFunctions) {
    - 23             scheduledFunc = this.scheduledFunctions[timeoutKey];
    - 24             if (scheduledFunc != undefined &&
    - 25                 scheduledFunc.runAtMillis >= oldMillis &&
    - 26                 scheduledFunc.runAtMillis <= nowMillis) {
    - 27                 funcsToRun.push(scheduledFunc);
    - 28                 this.scheduledFunctions[timeoutKey] = undefined;
    - 29             }
    - 30         }
    - 31 
    - 32         if (funcsToRun.length > 0) {
    - 33             funcsToRun.sort(function(a, b) {
    - 34                 return a.runAtMillis - b.runAtMillis;
    - 35             });
    - 36             for (var i = 0; i < funcsToRun.length; ++i) {
    - 37                 try {
    - 38                     this.nowMillis = funcsToRun[i].runAtMillis;
    - 39                     funcsToRun[i].funcToCall();
    - 40                     if (funcsToRun[i].recurring) {
    - 41                         Clock.scheduleFunction(funcsToRun[i].timeoutKey,
    - 42                                 funcsToRun[i].funcToCall,
    - 43                                 funcsToRun[i].millis,
    - 44                                 true);
    - 45                     }
    - 46                 } catch(e) {
    - 47                 }
    - 48             }
    - 49             this.runFunctionsWithinRange(oldMillis, nowMillis);
    - 50         }
    - 51     },
    - 52     scheduleFunction: function(timeoutKey, funcToCall, millis, recurring) {
    - 53         Clock.scheduledFunctions[timeoutKey] = {
    - 54             runAtMillis: Clock.nowMillis + millis,
    - 55             funcToCall: funcToCall,
    - 56             recurring: recurring,
    - 57             timeoutKey: timeoutKey,
    - 58             millis: millis
    - 59         };
    - 60     }
    - 61 };
    - 62 
    - 63 function setTimeout(funcToCall, millis) {
    - 64     Clock.timeoutsMade = Clock.timeoutsMade + 1;
    - 65     Clock.scheduleFunction(Clock.timeoutsMade, funcToCall, millis, false);
    - 66     return Clock.timeoutsMade;
    - 67 }
    - 68 
    - 69 function setInterval(funcToCall, millis) {
    - 70     Clock.timeoutsMade = Clock.timeoutsMade + 1;
    - 71     Clock.scheduleFunction(Clock.timeoutsMade, funcToCall, millis, true);
    - 72     return Clock.timeoutsMade;
    - 73 }
    - 74 
    - 75 function clearTimeout(timeoutKey) {
    - 76     Clock.scheduledFunctions[timeoutKey] = undefined;
    - 77 }
    - 78 
    - 79 function clearInterval(timeoutKey) {
    - 80     Clock.scheduledFunctions[timeoutKey] = undefined;
    - 81 }
    - 82 
    \ No newline at end of file diff --git a/doc/symbols/src/src_mock-timeout.js.html b/doc/symbols/src/src_mock-timeout.js.html deleted file mode 100644 index 9a087a5..0000000 --- a/doc/symbols/src/src_mock-timeout.js.html +++ /dev/null @@ -1,166 +0,0 @@ -
      1 // Mock setTimeout, clearTimeout
    -  2 // Contributed by Pivotal Computer Systems, www.pivotalsf.com
    -  3 
    -  4 jasmine.FakeTimer = function() {
    -  5   this.reset();
    -  6 
    -  7   var self = this;
    -  8   self.setTimeout = function(funcToCall, millis) {
    -  9     self.timeoutsMade++;
    - 10     self.scheduleFunction(self.timeoutsMade, funcToCall, millis, false);
    - 11     return self.timeoutsMade;
    - 12   };
    - 13 
    - 14   self.setInterval = function(funcToCall, millis) {
    - 15     self.timeoutsMade++;
    - 16     self.scheduleFunction(self.timeoutsMade, funcToCall, millis, true);
    - 17     return self.timeoutsMade;
    - 18   };
    - 19 
    - 20   self.clearTimeout = function(timeoutKey) {
    - 21     self.scheduledFunctions[timeoutKey] = undefined;
    - 22   };
    - 23 
    - 24   self.clearInterval = function(timeoutKey) {
    - 25     self.scheduledFunctions[timeoutKey] = undefined;
    - 26   };
    - 27 
    - 28 };
    - 29 
    - 30 jasmine.FakeTimer.prototype.reset = function() {
    - 31   this.timeoutsMade = 0;
    - 32   this.scheduledFunctions = {};
    - 33   this.nowMillis = 0;
    - 34 };
    - 35 
    - 36 jasmine.FakeTimer.prototype.tick = function(millis) {
    - 37   var oldMillis = this.nowMillis;
    - 38   var newMillis = oldMillis + millis;
    - 39   this.runFunctionsWithinRange(oldMillis, newMillis);
    - 40   this.nowMillis = newMillis;
    - 41 };
    - 42 
    - 43 jasmine.FakeTimer.prototype.runFunctionsWithinRange = function(oldMillis, nowMillis) {
    - 44   var scheduledFunc;
    - 45   var funcsToRun = [];
    - 46   for (var timeoutKey in this.scheduledFunctions) {
    - 47     scheduledFunc = this.scheduledFunctions[timeoutKey];
    - 48     if (scheduledFunc != undefined &&
    - 49         scheduledFunc.runAtMillis >= oldMillis &&
    - 50         scheduledFunc.runAtMillis <= nowMillis) {
    - 51       funcsToRun.push(scheduledFunc);
    - 52       this.scheduledFunctions[timeoutKey] = undefined;
    - 53     }
    - 54   }
    - 55 
    - 56   if (funcsToRun.length > 0) {
    - 57     funcsToRun.sort(function(a, b) {
    - 58       return a.runAtMillis - b.runAtMillis;
    - 59     });
    - 60     for (var i = 0; i < funcsToRun.length; ++i) {
    - 61       try {
    - 62         var funcToRun = funcsToRun[i];
    - 63         this.nowMillis = funcToRun.runAtMillis;
    - 64         funcToRun.funcToCall();
    - 65         if (funcToRun.recurring) {
    - 66           this.scheduleFunction(funcToRun.timeoutKey,
    - 67             funcToRun.funcToCall,
    - 68             funcToRun.millis,
    - 69             true);
    - 70         }
    - 71       } catch(e) {
    - 72       }
    - 73     }
    - 74     this.runFunctionsWithinRange(oldMillis, nowMillis);
    - 75   }
    - 76 };
    - 77 
    - 78 jasmine.FakeTimer.prototype.scheduleFunction = function(timeoutKey, funcToCall, millis, recurring) {
    - 79   this.scheduledFunctions[timeoutKey] = {
    - 80     runAtMillis: this.nowMillis + millis,
    - 81     funcToCall: funcToCall,
    - 82     recurring: recurring,
    - 83     timeoutKey: timeoutKey,
    - 84     millis: millis
    - 85   };
    - 86 };
    - 87 
    - 88 
    - 89 jasmine.Clock = {
    - 90   defaultFakeTimer: new jasmine.FakeTimer(),
    - 91 
    - 92   reset: function() {
    - 93     jasmine.Clock.assertInstalled();
    - 94     jasmine.Clock.defaultFakeTimer.reset();
    - 95   },
    - 96 
    - 97   tick: function(millis) {
    - 98     jasmine.Clock.assertInstalled();
    - 99     jasmine.Clock.defaultFakeTimer.tick(millis);
    -100   },
    -101 
    -102   runFunctionsWithinRange: function(oldMillis, nowMillis) {
    -103     jasmine.Clock.defaultFakeTimer.runFunctionsWithinRange(oldMillis, nowMillis);
    -104   },
    -105 
    -106   scheduleFunction: function(timeoutKey, funcToCall, millis, recurring) {
    -107     jasmine.Clock.defaultFakeTimer.scheduleFunction(timeoutKey, funcToCall, millis, recurring);
    -108   },
    -109 
    -110   useMock: function() {
    -111     var spec = jasmine.getEnv().currentSpec;
    -112     spec.after(jasmine.Clock.uninstallMock);
    -113 
    -114     jasmine.Clock.installMock();
    -115   },
    -116 
    -117   installMock: function() {
    -118     jasmine.Clock.installed = jasmine.Clock.defaultFakeTimer;
    -119   },
    -120 
    -121   uninstallMock: function() {
    -122     jasmine.Clock.assertInstalled();
    -123     jasmine.Clock.installed = jasmine.Clock.real;
    -124   },
    -125 
    -126   real: {
    -127     setTimeout: window.setTimeout,
    -128     clearTimeout: window.clearTimeout,
    -129     setInterval: window.setInterval,
    -130     clearInterval: window.clearInterval
    -131   },
    -132 
    -133   assertInstalled: function() {
    -134     if (jasmine.Clock.installed != jasmine.Clock.defaultFakeTimer) {
    -135       throw new Error("Mock clock is not installed, use jasmine.Clock.useMock()");
    -136     }
    -137   },  
    -138 
    -139   installed: null
    -140 };
    -141 jasmine.Clock.installed = jasmine.Clock.real;
    -142 
    -143 window.setTimeout = function(funcToCall, millis) {
    -144   return jasmine.Clock.installed.setTimeout.apply(this, arguments);
    -145 };
    -146 
    -147 window.setInterval = function(funcToCall, millis) {
    -148   return jasmine.Clock.installed.setInterval.apply(this, arguments);
    -149 };
    -150 
    -151 window.clearTimeout = function(timeoutKey) {
    -152   return jasmine.Clock.installed.clearTimeout.apply(this, arguments);
    -153 };
    -154 
    -155 window.clearInterval = function(timeoutKey) {
    -156   return jasmine.Clock.installed.clearInterval.apply(this, arguments);
    -157 };
    -158 
    -159 
    \ No newline at end of file diff --git a/doc/symbols/src/src_util.js.html b/doc/symbols/src/src_util.js.html deleted file mode 100644 index 7d80a0e..0000000 --- a/doc/symbols/src/src_util.js.html +++ /dev/null @@ -1,67 +0,0 @@ -
      1 /**
    -  2  * @namespace
    -  3  */
    -  4 jasmine.util = {};
    -  5 
    -  6 /**
    -  7  * Declare that a child class inherite it's prototype from the parent class.
    -  8  *
    -  9  * @private
    - 10  * @param {Function} childClass
    - 11  * @param {Function} parentClass
    - 12  */
    - 13 jasmine.util.inherit = function(childClass, parentClass) {
    - 14   var subclass = function() {
    - 15   };
    - 16   subclass.prototype = parentClass.prototype;
    - 17   childClass.prototype = new subclass;
    - 18 };
    - 19 
    - 20 jasmine.util.formatException = function(e) {
    - 21   var lineNumber;
    - 22   if (e.line) {
    - 23     lineNumber = e.line;
    - 24   }
    - 25   else if (e.lineNumber) {
    - 26     lineNumber = e.lineNumber;
    - 27   }
    - 28 
    - 29   var file;
    - 30 
    - 31   if (e.sourceURL) {
    - 32     file = e.sourceURL;
    - 33   }
    - 34   else if (e.fileName) {
    - 35     file = e.fileName;
    - 36   }
    - 37 
    - 38   var message = (e.name && e.message) ? (e.name + ': ' + e.message) : e.toString();
    - 39 
    - 40   if (file && lineNumber) {
    - 41     message += ' in ' + file + ' (line ' + lineNumber + ')';
    - 42   }
    - 43 
    - 44   return message;
    - 45 };
    - 46 
    - 47 jasmine.util.htmlEscape = function(str) {
    - 48   if (!str) return str;
    - 49   return str.replace(/&/g, '&')
    - 50     .replace(/</g, '<')
    - 51     .replace(/>/g, '>');
    - 52 };
    - 53 
    - 54 jasmine.util.argsToArray = function(args) {
    - 55   var arrayOfArgs = [];
    - 56   for (var i = 0; i < args.length; i++) arrayOfArgs.push(args[i]);
    - 57   return arrayOfArgs;
    - 58 };
    - 59 
    - 60 
    \ No newline at end of file diff --git a/lib/TrivialReporter.js b/lib/TrivialReporter.js index a7bd114..5d10f5d 100644 --- a/lib/TrivialReporter.js +++ b/lib/TrivialReporter.js @@ -18,11 +18,7 @@ jasmine.TrivialReporter.prototype.createDom = function(type, attrs, childrenVarA if (attr == 'className') { el.setAttribute('class', attrs[attr]); } else { - if (attr.indexOf('x-') == 0) { - el.setAttribute(attr, attrs[attr]); - } else { - el[attr] = attrs[attr]; - } + el[attr] = attrs[attr]; } } diff --git a/lib/jasmine.js b/lib/jasmine.js index f1579fa..c37406c 100644 --- a/lib/jasmine.js +++ b/lib/jasmine.js @@ -567,12 +567,19 @@ jasmine.util.argsToArray = function(args) { return arrayOfArgs; }; +/** + * Environment for Jasmine + * + * @constructor + */ jasmine.Env = function() { this.currentSpec = null; this.currentSuite = null; this.currentRunner = new jasmine.Runner(this); this.currentlyRunningTests = false; + this.reporter = new jasmine.MultiReporter(); + this.updateInterval = 0; this.lastUpdate = 0; this.specFilter = function() { @@ -589,6 +596,14 @@ jasmine.Env.prototype.clearTimeout = jasmine.clearTimeout; jasmine.Env.prototype.setInterval = jasmine.setInterval; jasmine.Env.prototype.clearInterval = jasmine.clearInterval; +/** + * Register a reporter to receive status updates from Jasmine. + * @param {jasmine.Reporter} reporter An object which will receive status updates. + */ +jasmine.Env.prototype.addReporter = function(reporter) { + this.reporter.addReporter(reporter); +}; + jasmine.Env.prototype.execute = function() { this.currentRunner.execute(); }; @@ -830,6 +845,33 @@ jasmine.ActionCollection.prototype.waitForDone = function(action) { } }, 150); }; +/** No-op base class for Jasmine reporters. + * + * @constructor + */ +jasmine.Reporter = function() { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportRunnerStarting = function(runner) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportRunnerResults = function(runner) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportSuiteResults = function(suite) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportSpecResults = function(spec) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.log = function (str) { +}; + jasmine.Matchers = function(env, actual, results) { this.env = env; this.actual = actual; @@ -1260,6 +1302,34 @@ window.clearInterval = function(timeoutKey) { return jasmine.Clock.installed.clearInterval.apply(this, arguments); }; +/** + * @constructor + */ +jasmine.MultiReporter = function() { + this.subReporters_ = []; +}; +jasmine.util.inherit(jasmine.MultiReporter, jasmine.Reporter); + +jasmine.MultiReporter.prototype.addReporter = function(reporter) { + this.subReporters_.push(reporter); +}; + +(function() { + var functionNames = ["reportRunnerStarting", "reportRunnerResults", "reportSuiteResults", "reportSpecResults", "log"]; + for (var i = 0; i < functionNames.length; i++) { + var functionName = functionNames[i]; + jasmine.MultiReporter.prototype[functionName] = (function(functionName) { + return function() { + for (var j = 0; j < this.subReporters_.length; j++) { + var subReporter = this.subReporters_[j]; + if (subReporter[functionName]) { + subReporter[functionName].apply(subReporter, arguments); + } + } + }; + })(functionName); + } +})(); /** * Holds results for a set of Jasmine spec. Allows for the results array to hold another jasmine.NestedResults * @@ -1481,9 +1551,7 @@ jasmine.QueuedFunction.prototype.next = function() { }; jasmine.QueuedFunction.prototype.safeExecute = function() { - if (this.env.reporter) { - this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...'); - } + this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...'); try { this.func.apply(this.spec); @@ -1587,10 +1655,15 @@ jasmine.Runner = function(env) { }; jasmine.util.inherit(jasmine.Runner, jasmine.ActionCollection); -jasmine.Runner.prototype.finishCallback = function() { - if (this.env.reporter) { - this.env.reporter.reportRunnerResults(this); +jasmine.Runner.prototype.execute = function() { + if (this.env.reporter.reportRunnerStarting) { + this.env.reporter.reportRunnerStarting(this); } + jasmine.ActionCollection.prototype.execute.call(this); +}; + +jasmine.Runner.prototype.finishCallback = function() { + this.env.reporter.reportRunnerResults(this); }; jasmine.Runner.prototype.getResults = function() { @@ -1602,8 +1675,8 @@ jasmine.Runner.prototype.getResults = function() { }; /** * Internal representation of a Jasmine specification, or test. - * @private - * @constructs + * + * @constructor * @param {jasmine.Env} env * @param {jasmine.Suite} suite * @param {String} description @@ -1623,6 +1696,7 @@ jasmine.Spec = function(env, suite, description) { this.results = new jasmine.NestedResults(); this.results.description = description; this.runs = this.addToQueue; + this.matchersClass = null; }; jasmine.Spec.prototype.getFullName = function() { @@ -1658,15 +1732,13 @@ jasmine.Spec.prototype.expects_that = function(actual) { /** * @private - * @deprecated */ jasmine.Spec.prototype.expect = function(actual) { - return new jasmine.Matchers(this.env, actual, this.results); + return new (this.getMatchersClass_())(this.env, actual, this.results); }; /** * @private - * @deprecated */ jasmine.Spec.prototype.waits = function(timeout) { this.currentTimeout = timeout; @@ -1676,7 +1748,6 @@ jasmine.Spec.prototype.waits = function(timeout) { /** * @private - * @deprecated */ jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, message) { this.currentTimeout = timeout; @@ -1685,15 +1756,29 @@ jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, message) { return this; }; +jasmine.Spec.prototype.getMatchersClass_ = function() { + return this.matchersClass || jasmine.Matchers; +}; + +jasmine.Spec.prototype.addMatchers = function(matchersPrototype) { + var parent = this.getMatchersClass_(); + var newMatchersClass = function() { + parent.apply(this, arguments); + }; + jasmine.util.inherit(newMatchersClass, parent); + for (var method in matchersPrototype) { + newMatchersClass.prototype[method] = matchersPrototype[method]; + } + this.matchersClass = newMatchersClass; +}; + jasmine.Spec.prototype.resetTimeout = function() { this.currentTimeout = 0; this.currentLatchFunction = undefined; }; jasmine.Spec.prototype.finishCallback = function() { - if (this.env.reporter) { - this.env.reporter.reportSpecResults(this); - } + this.env.reporter.reportSpecResults(this); }; jasmine.Spec.prototype.finish = function() { @@ -1792,7 +1877,7 @@ jasmine.Spec.prototype.removeAllSpies = function() { }; /** - * For storing & executing a Jasmine suite. + * Internal representation of a Jasmine suite. * * @constructor * @param {jasmine.Env} env @@ -1821,9 +1906,7 @@ jasmine.Suite.prototype.getFullName = function() { }; jasmine.Suite.prototype.finishCallback = function() { - if (this.env.reporter) { - this.env.reporter.reportSuiteResults(this); - } + this.env.reporter.reportSuiteResults(this); }; jasmine.Suite.prototype.beforeEach = function(beforeEachFunction) { diff --git a/spec/runner.html b/spec/runner.html index fe4bbd8..41c87bd 100644 --- a/spec/runner.html +++ b/spec/runner.html @@ -10,7 +10,9 @@ + + @@ -21,13 +23,14 @@ - diff --git a/spec/suites/EnvTest.js b/spec/suites/EnvTest.js new file mode 100644 index 0000000..62676ae --- /dev/null +++ b/spec/suites/EnvTest.js @@ -0,0 +1,17 @@ +describe("jasmine.Env", function() { + describe("reporting", function() { + var env; + var fakeReporter; + + beforeEach(function() { + env = new jasmine.Env(); + fakeReporter = jasmine.createSpyObj("fakeReporter", ["log"]); + }); + + it("should allow reporters to be registered", function() { + env.addReporter(fakeReporter); + env.reporter.log("message"); + expect(fakeReporter.log).wasCalledWith("message"); + }); + }); +}); \ No newline at end of file diff --git a/spec/suites/MultiReporterTest.js b/spec/suites/MultiReporterTest.js new file mode 100644 index 0000000..1118efa --- /dev/null +++ b/spec/suites/MultiReporterTest.js @@ -0,0 +1,30 @@ +describe("jasmine.MultiReporter", function() { + var multiReporter, fakeReporter1, fakeReporter2; + + beforeEach(function() { + multiReporter = new jasmine.MultiReporter(); + fakeReporter1 = jasmine.createSpyObj("fakeReporter1", ["reportSpecResults"]); + fakeReporter2 = jasmine.createSpyObj("fakeReporter2", ["reportSpecResults", "reportRunnerStarting"]); + multiReporter.addReporter(fakeReporter1); + multiReporter.addReporter(fakeReporter2); + }); + + it("should support all the method calls that jasmine.Reporter supports", function() { + multiReporter.reportRunnerStarting(); + multiReporter.reportRunnerResults(); + multiReporter.reportSuiteResults(); + multiReporter.reportSpecResults(); + multiReporter.log(); + }); + + it("should delegate to any and all subreporters", function() { + multiReporter.reportSpecResults('blah', 'foo'); + expect(fakeReporter1.reportSpecResults).wasCalledWith('blah', 'foo'); + expect(fakeReporter2.reportSpecResults).wasCalledWith('blah', 'foo'); + }); + + it("should quietly skip delegating to any subreporters which lack the given method", function() { + multiReporter.reportRunnerStarting('blah', 'foo'); + expect(fakeReporter2.reportRunnerStarting).wasCalledWith('blah', 'foo'); + }); +}); \ No newline at end of file diff --git a/spec/suites/RunnerTest.js b/spec/suites/RunnerTest.js index 1bcf6bf..c0009b3 100644 --- a/spec/suites/RunnerTest.js +++ b/spec/suites/RunnerTest.js @@ -114,4 +114,13 @@ describe('RunnerTest', function() { expect(foo).toEqual(1); }); + it("should report when the tests start running", function() { + var fakeReporter = jasmine.createSpyObj("fakeReporter", ["log", "reportRunnerStarting"]); + env.addReporter(fakeReporter); + + var runner = new jasmine.Runner(env); + runner.execute(); + expect(fakeReporter.reportRunnerStarting).wasCalledWith(env.currentRunner); + }); + }); \ No newline at end of file diff --git a/spec/suites/SpecRunningTest.js b/spec/suites/SpecRunningTest.js index d74f5f3..ca84e1d 100644 --- a/spec/suites/SpecRunningTest.js +++ b/spec/suites/SpecRunningTest.js @@ -728,4 +728,36 @@ describe("jasmine spec running", function () { expect(exceptionMessage).toEqual('explodes function should not have been called'); }); + + it("should be easy to add more matchers local to a spec, suite, etc.", function() { + var spec1, spec2, spec1Matcher, spec2Matcher; + + var suite = env.describe('some suite', function() { + env.beforeEach(function() { + this.addMatchers({ matcherForSuite: function(expected) { + return "matcherForSuite: actual: " + this.actual + "; expected: " + expected; + } }); + }); + + spec1 = env.it('spec with an expectation').runs(function () { + this.addMatchers( { matcherForSpec: function(expected) { + return "matcherForSpec: actual: " + this.actual + "; expected: " + expected; + } }); + spec1Matcher = this.expect("xxx"); + }); + + spec2 = env.it('spec with failing expectation').runs(function () { + spec2Matcher = this.expect("yyy"); + }); + }); + + suite.execute(); + + expect(spec1Matcher.matcherForSuite("expected")).toEqual("matcherForSuite: actual: xxx; expected: expected"); + expect(spec1Matcher.matcherForSpec("expected")).toEqual("matcherForSpec: actual: xxx; expected: expected"); + + expect(spec2Matcher.matcherForSuite("expected")).toEqual("matcherForSuite: actual: yyy; expected: expected"); + expect(spec2Matcher.matcherForSpec).toBe(undefined); + }); + }); diff --git a/spec/suites/SpyTest.js b/spec/suites/SpyTest.js index 0e8347b..1e782fb 100644 --- a/spec/suites/SpyTest.js +++ b/spec/suites/SpyTest.js @@ -143,7 +143,7 @@ describe('Spies', function () { }); it('calls removeAllSpies during spec finish', function() { - var test = new jasmine.Spec({}, {}, 'sample test'); + var test = new jasmine.Spec(new jasmine.Env(), {}, 'sample test'); this.spyOn(test, 'removeAllSpies'); diff --git a/src/Env.js b/src/Env.js index 0708a8c..fd4dc70 100644 --- a/src/Env.js +++ b/src/Env.js @@ -1,9 +1,16 @@ +/** + * Environment for Jasmine + * + * @constructor + */ jasmine.Env = function() { this.currentSpec = null; this.currentSuite = null; this.currentRunner = new jasmine.Runner(this); this.currentlyRunningTests = false; + this.reporter = new jasmine.MultiReporter(); + this.updateInterval = 0; this.lastUpdate = 0; this.specFilter = function() { @@ -20,6 +27,14 @@ jasmine.Env.prototype.clearTimeout = jasmine.clearTimeout; jasmine.Env.prototype.setInterval = jasmine.setInterval; jasmine.Env.prototype.clearInterval = jasmine.clearInterval; +/** + * Register a reporter to receive status updates from Jasmine. + * @param {jasmine.Reporter} reporter An object which will receive status updates. + */ +jasmine.Env.prototype.addReporter = function(reporter) { + this.reporter.addReporter(reporter); +}; + jasmine.Env.prototype.execute = function() { this.currentRunner.execute(); }; diff --git a/src/MultiReporter.js b/src/MultiReporter.js new file mode 100644 index 0000000..cb8110a --- /dev/null +++ b/src/MultiReporter.js @@ -0,0 +1,28 @@ +/** + * @constructor + */ +jasmine.MultiReporter = function() { + this.subReporters_ = []; +}; +jasmine.util.inherit(jasmine.MultiReporter, jasmine.Reporter); + +jasmine.MultiReporter.prototype.addReporter = function(reporter) { + this.subReporters_.push(reporter); +}; + +(function() { + var functionNames = ["reportRunnerStarting", "reportRunnerResults", "reportSuiteResults", "reportSpecResults", "log"]; + for (var i = 0; i < functionNames.length; i++) { + var functionName = functionNames[i]; + jasmine.MultiReporter.prototype[functionName] = (function(functionName) { + return function() { + for (var j = 0; j < this.subReporters_.length; j++) { + var subReporter = this.subReporters_[j]; + if (subReporter[functionName]) { + subReporter[functionName].apply(subReporter, arguments); + } + } + }; + })(functionName); + } +})(); diff --git a/src/QueuedFunction.js b/src/QueuedFunction.js index f2fc777..e4845c3 100644 --- a/src/QueuedFunction.js +++ b/src/QueuedFunction.js @@ -24,9 +24,7 @@ jasmine.QueuedFunction.prototype.next = function() { }; jasmine.QueuedFunction.prototype.safeExecute = function() { - if (this.env.reporter) { - this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...'); - } + this.env.reporter.log('>> Jasmine Running ' + this.spec.suite.description + ' ' + this.spec.description + '...'); try { this.func.apply(this.spec); diff --git a/src/Reporter.js b/src/Reporter.js new file mode 100644 index 0000000..0e4350c --- /dev/null +++ b/src/Reporter.js @@ -0,0 +1,27 @@ +/** No-op base class for Jasmine reporters. + * + * @constructor + */ +jasmine.Reporter = function() { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportRunnerStarting = function(runner) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportRunnerResults = function(runner) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportSuiteResults = function(suite) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.reportSpecResults = function(spec) { +}; + +//noinspection JSUnusedLocalSymbols +jasmine.Reporter.prototype.log = function (str) { +}; + diff --git a/src/Runner.js b/src/Runner.js index 22a1996..725cbe1 100644 --- a/src/Runner.js +++ b/src/Runner.js @@ -11,10 +11,15 @@ jasmine.Runner = function(env) { }; jasmine.util.inherit(jasmine.Runner, jasmine.ActionCollection); -jasmine.Runner.prototype.finishCallback = function() { - if (this.env.reporter) { - this.env.reporter.reportRunnerResults(this); +jasmine.Runner.prototype.execute = function() { + if (this.env.reporter.reportRunnerStarting) { + this.env.reporter.reportRunnerStarting(this); } + jasmine.ActionCollection.prototype.execute.call(this); +}; + +jasmine.Runner.prototype.finishCallback = function() { + this.env.reporter.reportRunnerResults(this); }; jasmine.Runner.prototype.getResults = function() { diff --git a/src/Spec.js b/src/Spec.js index aef5ac2..d754382 100644 --- a/src/Spec.js +++ b/src/Spec.js @@ -1,7 +1,7 @@ /** * Internal representation of a Jasmine specification, or test. - * @private - * @constructs + * + * @constructor * @param {jasmine.Env} env * @param {jasmine.Suite} suite * @param {String} description @@ -21,6 +21,7 @@ jasmine.Spec = function(env, suite, description) { this.results = new jasmine.NestedResults(); this.results.description = description; this.runs = this.addToQueue; + this.matchersClass = null; }; jasmine.Spec.prototype.getFullName = function() { @@ -56,15 +57,13 @@ jasmine.Spec.prototype.expects_that = function(actual) { /** * @private - * @deprecated */ jasmine.Spec.prototype.expect = function(actual) { - return new jasmine.Matchers(this.env, actual, this.results); + return new (this.getMatchersClass_())(this.env, actual, this.results); }; /** * @private - * @deprecated */ jasmine.Spec.prototype.waits = function(timeout) { this.currentTimeout = timeout; @@ -74,7 +73,6 @@ jasmine.Spec.prototype.waits = function(timeout) { /** * @private - * @deprecated */ jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, message) { this.currentTimeout = timeout; @@ -83,15 +81,29 @@ jasmine.Spec.prototype.waitsFor = function(timeout, latchFunction, message) { return this; }; +jasmine.Spec.prototype.getMatchersClass_ = function() { + return this.matchersClass || jasmine.Matchers; +}; + +jasmine.Spec.prototype.addMatchers = function(matchersPrototype) { + var parent = this.getMatchersClass_(); + var newMatchersClass = function() { + parent.apply(this, arguments); + }; + jasmine.util.inherit(newMatchersClass, parent); + for (var method in matchersPrototype) { + newMatchersClass.prototype[method] = matchersPrototype[method]; + } + this.matchersClass = newMatchersClass; +}; + jasmine.Spec.prototype.resetTimeout = function() { this.currentTimeout = 0; this.currentLatchFunction = undefined; }; jasmine.Spec.prototype.finishCallback = function() { - if (this.env.reporter) { - this.env.reporter.reportSpecResults(this); - } + this.env.reporter.reportSpecResults(this); }; jasmine.Spec.prototype.finish = function() { diff --git a/src/Suite.js b/src/Suite.js index aa206d4..60ac46c 100644 --- a/src/Suite.js +++ b/src/Suite.js @@ -1,5 +1,5 @@ /** - * For storing & executing a Jasmine suite. + * Internal representation of a Jasmine suite. * * @constructor * @param {jasmine.Env} env @@ -28,9 +28,7 @@ jasmine.Suite.prototype.getFullName = function() { }; jasmine.Suite.prototype.finishCallback = function() { - if (this.env.reporter) { - this.env.reporter.reportSuiteResults(this); - } + this.env.reporter.reportSuiteResults(this); }; jasmine.Suite.prototype.beforeEach = function(beforeEachFunction) {