summaryrefslogtreecommitdiff
path: root/misc/openlayers/tests/throws.js
blob: 0e2ac9a9296e2faee1c1463eb8eaae7bed5c0402 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*

  throws.js -- Adds a `throws_` method to AnotherWay test objects.

  Copyright 2005 OpenLayers Contributors. released under the BSD License.


  A reference to this file needs to be added to `run-tests.html` in the
  head element after the AnotherWay classes are created:

    <script type="text/javascript" src="throws.js"></script>

  Then, it can be used just like the `ok`, `fail` and other such methods
  in your unit tests.

  e.g. 

   t.throws_(function () {new OpenLayers.View.Map.Dynamic();},
             ReferenceError("No container supplied."),
             "OpenLayers.View.Map.Dynamic instantiation with no container "
             + "must throw.");

  This was inspired by the `assertRaises` method of Python's unittest
  library.

  Possible future enhancements:

    * Contribute to official AnotherWay distribution.
    * Use `apply` rather than require a inner function (or as an option).
    * Preserve the stack fields.

 */

Test.AnotherWay._test_object_t.prototype.throws_ = 
function (fn, expectedException, doc) {
    /*
      
       Executes the supplied function object catching any exception(s)
       thrown, then verifies the supplied expected exception occurred.
      
       If no exception is thrown the test fails.

       If an exception is thrown and it does not match the supplied
       expected exception the test fails.

       If the exception thrown matches the supplied expected exception
       the test passes.

       Two exceptions "match" if Test.AnotherWay's `eq` method considers
       the two equal when their respective stacks are ignored.

                      fn - The function object to be executed
       expectedException - The exception object expected to result
                     doc - Description of the test

       Note: The name of this method is `throws_` (with a trailing
             underscore) as `throws` is a reserved identifier and can
             not be used as a method name.

       Note: This function does not preserve the stack field associated
             with either exception.

     */
    var theCaughtException = null;

    try {
        fn();
    } catch (innerCaughtException) {
        // As `innerCaughtException` is not visible outside the scope
        // of this `catch` block we need to make it visible explicitly. 
        theCaughtException = innerCaughtException;
    }

    if (theCaughtException) {
        // We delete the stacks before comparison as they will never match.
        delete theCaughtException.stack;
        delete expectedException.stack;
        this.eq(theCaughtException, expectedException, doc);
    } else {
        this.fail(doc);
    }
};