├── .codesandbox
└── workspace.json
├── .github
└── workflows
│ └── validate.yml
├── .gitignore
├── .prettierrc
├── coverage
├── clover.xml
├── coverage-final.json
├── lcov-report
│ ├── base.css
│ ├── block-navigation.js
│ ├── component-did-catch.js.html
│ ├── favicon.png
│ ├── fetch-greeting.js.html
│ ├── index.html
│ ├── index.js.html
│ ├── lazy-component.js.html
│ ├── prettify.css
│ ├── prettify.js
│ ├── react-context.js.html
│ ├── sort-arrow-sprite.png
│ ├── sorter.js
│ └── utils.js.html
└── lcov.info
├── package.json
├── public
└── index.html
├── sandbox.config.json
└── src
├── __tests__
├── async.js
├── component-did-catch.js
├── i18next.js
├── mock.react-router.js
├── mock.react-transition-group.js
├── on-change.js
├── portals.js
├── react-context.js
├── react-intl.js
├── react-lazy-and-suspense.js
├── react-redux.js
├── react-router.js
├── shallow.react-transition-group.js
├── update-props.js
├── upload-file.js
└── window-resize.js
├── component-did-catch.js
├── fetch-greeting.js
├── index.js
├── lazy-component.js
├── react-context.js
├── setupTests.js
└── utils.js
/.codesandbox/workspace.json:
--------------------------------------------------------------------------------
1 | {
2 | "preview": [
3 | {
4 | "views": [
5 | {
6 | "id": "codesandbox.tests"
7 | },
8 | {
9 | "id": "codesandbox.browser"
10 | }
11 | ]
12 | },
13 | {
14 | "views": [
15 | {
16 | "id": "codesandbox.console"
17 | },
18 | {
19 | "id": "codesandbox.problems"
20 | }
21 | ]
22 | }
23 | ]
24 | }
--------------------------------------------------------------------------------
/.github/workflows/validate.yml:
--------------------------------------------------------------------------------
1 | name: validate
2 | on:
3 | - push
4 |
5 | concurrency:
6 | group: ${{ github.workflow }}-${{ github.ref }}
7 | cancel-in-progress: true
8 |
9 | jobs:
10 | main:
11 | runs-on: ubuntu-latest
12 | steps:
13 | - name: ⬇️ Checkout repo
14 | uses: actions/checkout@v2
15 |
16 | - name: ⎔ Setup node
17 | uses: actions/setup-node@v1
18 |
19 | - name: 📥 Download deps
20 | uses: bahmutov/npm-install@v1
21 | with:
22 | useLockFile: false
23 |
24 | - name: 🧪 Run test script
25 | run: npm run test:coverage
26 |
27 | - name: 🏗 Run build script
28 | run: npm run build
29 |
30 | - name: ⬆️ Upload coverage report
31 | uses: codecov/codecov-action@v1
32 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | node_modules/
2 | build
3 | package-lock.json
4 | yarn.lock
5 |
--------------------------------------------------------------------------------
/.prettierrc:
--------------------------------------------------------------------------------
1 | {
2 | "printWidth": 80,
3 | "tabWidth": 2,
4 | "useTabs": false,
5 | "semi": false,
6 | "singleQuote": true,
7 | "trailingComma": "all",
8 | "bracketSpacing": false,
9 | "jsxBracketSameLine": false,
10 | "arrowParens": "avoid"
11 | }
12 |
--------------------------------------------------------------------------------
/coverage/clover.xml:
--------------------------------------------------------------------------------
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 |
--------------------------------------------------------------------------------
/coverage/coverage-final.json:
--------------------------------------------------------------------------------
1 | {"/Users/kentcdodds/Desktop/react-testing-library-examples/src/component-did-catch.js": {"path":"/Users/kentcdodds/Desktop/react-testing-library-examples/src/component-did-catch.js","statementMap":{"0":{"start":{"line":5,"column":10},"end":{"line":5,"column":27}},"1":{"start":{"line":7,"column":4},"end":{"line":7,"column":35}},"2":{"start":{"line":8,"column":4},"end":{"line":8,"column":28}},"3":{"start":{"line":11,"column":4},"end":{"line":15,"column":5}},"4":{"start":{"line":21,"column":4},"end":{"line":21,"column":30}},"5":{"start":{"line":26,"column":10},"end":{"line":26,"column":29}},"6":{"start":{"line":27,"column":20},"end":{"line":27,"column":59}},"7":{"start":{"line":27,"column":26},"end":{"line":27,"column":59}},"8":{"start":{"line":29,"column":4},"end":{"line":41,"column":5}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":6,"column":2},"end":{"line":6,"column":3}},"loc":{"start":{"line":6,"column":33},"end":{"line":9,"column":3}},"line":6},"1":{"name":"(anonymous_1)","decl":{"start":{"line":10,"column":2},"end":{"line":10,"column":3}},"loc":{"start":{"line":10,"column":11},"end":{"line":16,"column":3}},"line":10},"2":{"name":"(anonymous_2)","decl":{"start":{"line":20,"column":2},"end":{"line":20,"column":3}},"loc":{"start":{"line":20,"column":11},"end":{"line":22,"column":3}},"line":20},"3":{"name":"(anonymous_3)","decl":{"start":{"line":27,"column":20},"end":{"line":27,"column":21}},"loc":{"start":{"line":27,"column":26},"end":{"line":27,"column":59}},"line":27},"4":{"name":"(anonymous_4)","decl":{"start":{"line":28,"column":2},"end":{"line":28,"column":3}},"loc":{"start":{"line":28,"column":11},"end":{"line":42,"column":3}},"line":28}},"branchMap":{"0":{"loc":{"start":{"line":11,"column":11},"end":{"line":15,"column":5}},"type":"cond-expr","locations":[{"start":{"line":12,"column":6},"end":{"line":12,"column":36}},{"start":{"line":14,"column":6},"end":{"line":14,"column":25}}],"line":11},"1":{"loc":{"start":{"line":31,"column":9},"end":{"line":39,"column":9}},"type":"cond-expr","locations":[{"start":{"line":32,"column":10},"end":{"line":32,"column":18}},{"start":{"line":34,"column":10},"end":{"line":38,"column":19}}],"line":31}},"s":{"0":1,"1":1,"2":1,"3":3,"4":2,"5":1,"6":1,"7":1,"8":2},"f":{"0":1,"1":3,"2":2,"3":1,"4":2},"b":{"0":[1,2],"1":[1,1]},"_coverageSchema":"1a1c01bbd47fc00a2c39e90264f33305004495a9","hash":"df62e411584b1bab3f446a399ccdf8caf262a4fe"}
2 | ,"/Users/kentcdodds/Desktop/react-testing-library-examples/src/fetch-greeting.js": {"path":"/Users/kentcdodds/Desktop/react-testing-library-examples/src/fetch-greeting.js","statementMap":{"0":{"start":{"line":5,"column":21},"end":{"line":8,"column":1}},"1":{"start":{"line":11,"column":2},"end":{"line":27,"column":3}},"2":{"start":{"line":13,"column":6},"end":{"line":16,"column":7}},"3":{"start":{"line":19,"column":6},"end":{"line":22,"column":7}},"4":{"start":{"line":25,"column":6},"end":{"line":25,"column":18}},"5":{"start":{"line":31,"column":40},"end":{"line":34,"column":3}},"6":{"start":{"line":35,"column":44},"end":{"line":35,"column":59}},"7":{"start":{"line":37,"column":24},"end":{"line":49,"column":3}},"8":{"start":{"line":38,"column":4},"end":{"line":48,"column":8}},"9":{"start":{"line":41,"column":23},"end":{"line":41,"column":31}},"10":{"start":{"line":42,"column":27},"end":{"line":42,"column":31}},"11":{"start":{"line":43,"column":8},"end":{"line":43,"column":45}},"12":{"start":{"line":44,"column":8},"end":{"line":44,"column":30}},"13":{"start":{"line":47,"column":8},"end":{"line":47,"column":40}},"14":{"start":{"line":51,"column":21},"end":{"line":51,"column":59}},"15":{"start":{"line":53,"column":2},"end":{"line":61,"column":3}}},"fnMap":{"0":{"name":"greetingReducer","decl":{"start":{"line":10,"column":9},"end":{"line":10,"column":24}},"loc":{"start":{"line":10,"column":40},"end":{"line":28,"column":1}},"line":10},"1":{"name":"FetchGreeting","decl":{"start":{"line":30,"column":9},"end":{"line":30,"column":22}},"loc":{"start":{"line":30,"column":25},"end":{"line":62,"column":1}},"line":30},"2":{"name":"(anonymous_2)","decl":{"start":{"line":37,"column":24},"end":{"line":37,"column":25}},"loc":{"start":{"line":37,"column":36},"end":{"line":49,"column":3}},"line":37},"3":{"name":"(anonymous_3)","decl":{"start":{"line":40,"column":12},"end":{"line":40,"column":13}},"loc":{"start":{"line":40,"column":26},"end":{"line":45,"column":7}},"line":40},"4":{"name":"(anonymous_4)","decl":{"start":{"line":46,"column":13},"end":{"line":46,"column":14}},"loc":{"start":{"line":46,"column":24},"end":{"line":48,"column":7}},"line":46}},"branchMap":{"0":{"loc":{"start":{"line":11,"column":2},"end":{"line":27,"column":3}},"type":"switch","locations":[{"start":{"line":12,"column":4},"end":{"line":17,"column":5}},{"start":{"line":18,"column":4},"end":{"line":23,"column":5}},{"start":{"line":24,"column":4},"end":{"line":26,"column":5}}],"line":11},"1":{"loc":{"start":{"line":51,"column":21},"end":{"line":51,"column":59}},"type":"cond-expr","locations":[{"start":{"line":51,"column":37},"end":{"line":51,"column":41}},{"start":{"line":51,"column":44},"end":{"line":51,"column":59}}],"line":51},"2":{"loc":{"start":{"line":58,"column":7},"end":{"line":58,"column":38}},"type":"binary-expr","locations":[{"start":{"line":58,"column":7},"end":{"line":58,"column":15}},{"start":{"line":58,"column":19},"end":{"line":58,"column":38}}],"line":58},"3":{"loc":{"start":{"line":59,"column":7},"end":{"line":59,"column":58}},"type":"binary-expr","locations":[{"start":{"line":59,"column":7},"end":{"line":59,"column":12}},{"start":{"line":59,"column":16},"end":{"line":59,"column":58}}],"line":59}},"s":{"0":1,"1":2,"2":1,"3":1,"4":0,"5":5,"6":5,"7":5,"8":2,"9":1,"10":1,"11":1,"12":1,"13":1,"14":5,"15":5},"f":{"0":2,"1":5,"2":2,"3":1,"4":1},"b":{"0":[1,1,0],"1":[1,4],"2":[5,2],"3":[5,1]},"_coverageSchema":"1a1c01bbd47fc00a2c39e90264f33305004495a9","hash":"3ff91edf72ec5a93da5125b9d48a0970647b33d3"}
3 | ,"/Users/kentcdodds/Desktop/react-testing-library-examples/src/index.js": {"path":"/Users/kentcdodds/Desktop/react-testing-library-examples/src/index.js","statementMap":{"0":{"start":{"line":5,"column":2},"end":{"line":38,"column":3}},"1":{"start":{"line":41,"column":0},"end":{"line":41,"column":48}}},"fnMap":{"0":{"name":"App","decl":{"start":{"line":4,"column":9},"end":{"line":4,"column":12}},"loc":{"start":{"line":4,"column":15},"end":{"line":39,"column":1}},"line":4}},"branchMap":{},"s":{"0":0,"1":0},"f":{"0":0},"b":{}}
4 | ,"/Users/kentcdodds/Desktop/react-testing-library-examples/src/lazy-component.js": {"path":"/Users/kentcdodds/Desktop/react-testing-library-examples/src/lazy-component.js","statementMap":{"0":{"start":{"line":4,"column":2},"end":{"line":4,"column":30}}},"fnMap":{"0":{"name":"LazyComponent","decl":{"start":{"line":3,"column":9},"end":{"line":3,"column":22}},"loc":{"start":{"line":3,"column":25},"end":{"line":5,"column":1}},"line":3}},"branchMap":{},"s":{"0":2},"f":{"0":2},"b":{},"_coverageSchema":"1a1c01bbd47fc00a2c39e90264f33305004495a9","hash":"aea0971e644548027b45cf610d5ea0ab22298143"}
5 | ,"/Users/kentcdodds/Desktop/react-testing-library-examples/src/react-context.js": {"path":"/Users/kentcdodds/Desktop/react-testing-library-examples/src/react-context.js","statementMap":{"0":{"start":{"line":3,"column":20},"end":{"line":3,"column":50}},"1":{"start":{"line":5,"column":21},"end":{"line":10,"column":1}},"2":{"start":{"line":6,"column":19},"end":{"line":6,"column":37}},"3":{"start":{"line":7,"column":2},"end":{"line":9,"column":3}},"4":{"start":{"line":12,"column":21},"end":{"line":16,"column":1}},"5":{"start":{"line":13,"column":2},"end":{"line":15,"column":25}},"6":{"start":{"line":14,"column":14},"end":{"line":14,"column":44}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":5,"column":21},"end":{"line":5,"column":22}},"loc":{"start":{"line":5,"column":50},"end":{"line":10,"column":1}},"line":5},"1":{"name":"(anonymous_1)","decl":{"start":{"line":12,"column":21},"end":{"line":12,"column":22}},"loc":{"start":{"line":13,"column":2},"end":{"line":15,"column":25}},"line":13},"2":{"name":"(anonymous_2)","decl":{"start":{"line":14,"column":5},"end":{"line":14,"column":6}},"loc":{"start":{"line":14,"column":14},"end":{"line":14,"column":44}},"line":14}},"branchMap":{},"s":{"0":1,"1":1,"2":2,"3":2,"4":1,"5":3,"6":3},"f":{"0":2,"1":3,"2":3},"b":{},"_coverageSchema":"1a1c01bbd47fc00a2c39e90264f33305004495a9","hash":"6ce0b108c1f289b7cef74a582ac7a72b69c39f57"}
6 | ,"/Users/kentcdodds/Desktop/react-testing-library-examples/src/utils.js": {"path":"/Users/kentcdodds/Desktop/react-testing-library-examples/src/utils.js","statementMap":{"0":{"start":{"line":4,"column":2},"end":{"line":4,"column":41}}},"fnMap":{"0":{"name":"reportError","decl":{"start":{"line":1,"column":9},"end":{"line":1,"column":20}},"loc":{"start":{"line":1,"column":23},"end":{"line":5,"column":1}},"line":1}},"branchMap":{},"s":{"0":0},"f":{"0":0},"b":{}}
7 | }
8 |
--------------------------------------------------------------------------------
/coverage/lcov-report/base.css:
--------------------------------------------------------------------------------
1 | body, html {
2 | margin:0; padding: 0;
3 | height: 100%;
4 | }
5 | body {
6 | font-family: Helvetica Neue, Helvetica, Arial;
7 | font-size: 14px;
8 | color:#333;
9 | }
10 | .small { font-size: 12px; }
11 | *, *:after, *:before {
12 | -webkit-box-sizing:border-box;
13 | -moz-box-sizing:border-box;
14 | box-sizing:border-box;
15 | }
16 | h1 { font-size: 20px; margin: 0;}
17 | h2 { font-size: 14px; }
18 | pre {
19 | font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
20 | margin: 0;
21 | padding: 0;
22 | -moz-tab-size: 2;
23 | -o-tab-size: 2;
24 | tab-size: 2;
25 | }
26 | a { color:#0074D9; text-decoration:none; }
27 | a:hover { text-decoration:underline; }
28 | .strong { font-weight: bold; }
29 | .space-top1 { padding: 10px 0 0 0; }
30 | .pad2y { padding: 20px 0; }
31 | .pad1y { padding: 10px 0; }
32 | .pad2x { padding: 0 20px; }
33 | .pad2 { padding: 20px; }
34 | .pad1 { padding: 10px; }
35 | .space-left2 { padding-left:55px; }
36 | .space-right2 { padding-right:20px; }
37 | .center { text-align:center; }
38 | .clearfix { display:block; }
39 | .clearfix:after {
40 | content:'';
41 | display:block;
42 | height:0;
43 | clear:both;
44 | visibility:hidden;
45 | }
46 | .fl { float: left; }
47 | @media only screen and (max-width:640px) {
48 | .col3 { width:100%; max-width:100%; }
49 | .hide-mobile { display:none!important; }
50 | }
51 |
52 | .quiet {
53 | color: #7f7f7f;
54 | color: rgba(0,0,0,0.5);
55 | }
56 | .quiet a { opacity: 0.7; }
57 |
58 | .fraction {
59 | font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
60 | font-size: 10px;
61 | color: #555;
62 | background: #E8E8E8;
63 | padding: 4px 5px;
64 | border-radius: 3px;
65 | vertical-align: middle;
66 | }
67 |
68 | div.path a:link, div.path a:visited { color: #333; }
69 | table.coverage {
70 | border-collapse: collapse;
71 | margin: 10px 0 0 0;
72 | padding: 0;
73 | }
74 |
75 | table.coverage td {
76 | margin: 0;
77 | padding: 0;
78 | vertical-align: top;
79 | }
80 | table.coverage td.line-count {
81 | text-align: right;
82 | padding: 0 5px 0 20px;
83 | }
84 | table.coverage td.line-coverage {
85 | text-align: right;
86 | padding-right: 10px;
87 | min-width:20px;
88 | }
89 |
90 | table.coverage td span.cline-any {
91 | display: inline-block;
92 | padding: 0 5px;
93 | width: 100%;
94 | }
95 | .missing-if-branch {
96 | display: inline-block;
97 | margin-right: 5px;
98 | border-radius: 3px;
99 | position: relative;
100 | padding: 0 4px;
101 | background: #333;
102 | color: yellow;
103 | }
104 |
105 | .skip-if-branch {
106 | display: none;
107 | margin-right: 10px;
108 | position: relative;
109 | padding: 0 4px;
110 | background: #ccc;
111 | color: white;
112 | }
113 | .missing-if-branch .typ, .skip-if-branch .typ {
114 | color: inherit !important;
115 | }
116 | .coverage-summary {
117 | border-collapse: collapse;
118 | width: 100%;
119 | }
120 | .coverage-summary tr { border-bottom: 1px solid #bbb; }
121 | .keyline-all { border: 1px solid #ddd; }
122 | .coverage-summary td, .coverage-summary th { padding: 10px; }
123 | .coverage-summary tbody { border: 1px solid #bbb; }
124 | .coverage-summary td { border-right: 1px solid #bbb; }
125 | .coverage-summary td:last-child { border-right: none; }
126 | .coverage-summary th {
127 | text-align: left;
128 | font-weight: normal;
129 | white-space: nowrap;
130 | }
131 | .coverage-summary th.file { border-right: none !important; }
132 | .coverage-summary th.pct { }
133 | .coverage-summary th.pic,
134 | .coverage-summary th.abs,
135 | .coverage-summary td.pct,
136 | .coverage-summary td.abs { text-align: right; }
137 | .coverage-summary td.file { white-space: nowrap; }
138 | .coverage-summary td.pic { min-width: 120px !important; }
139 | .coverage-summary tfoot td { }
140 |
141 | .coverage-summary .sorter {
142 | height: 10px;
143 | width: 7px;
144 | display: inline-block;
145 | margin-left: 0.5em;
146 | background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
147 | }
148 | .coverage-summary .sorted .sorter {
149 | background-position: 0 -20px;
150 | }
151 | .coverage-summary .sorted-desc .sorter {
152 | background-position: 0 -10px;
153 | }
154 | .status-line { height: 10px; }
155 | /* yellow */
156 | .cbranch-no { background: yellow !important; color: #111; }
157 | /* dark red */
158 | .red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
159 | .low .chart { border:1px solid #C21F39 }
160 | .highlighted,
161 | .highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{
162 | background: #C21F39 !important;
163 | }
164 | /* medium red */
165 | .cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
166 | /* light red */
167 | .low, .cline-no { background:#FCE1E5 }
168 | /* light green */
169 | .high, .cline-yes { background:rgb(230,245,208) }
170 | /* medium green */
171 | .cstat-yes { background:rgb(161,215,106) }
172 | /* dark green */
173 | .status-line.high, .high .cover-fill { background:rgb(77,146,33) }
174 | .high .chart { border:1px solid rgb(77,146,33) }
175 | /* dark yellow (gold) */
176 | .status-line.medium, .medium .cover-fill { background: #f9cd0b; }
177 | .medium .chart { border:1px solid #f9cd0b; }
178 | /* light yellow */
179 | .medium { background: #fff4c2; }
180 |
181 | .cstat-skip { background: #ddd; color: #111; }
182 | .fstat-skip { background: #ddd; color: #111 !important; }
183 | .cbranch-skip { background: #ddd !important; color: #111; }
184 |
185 | span.cline-neutral { background: #eaeaea; }
186 |
187 | .coverage-summary td.empty {
188 | opacity: .5;
189 | padding-top: 4px;
190 | padding-bottom: 4px;
191 | line-height: 1;
192 | color: #888;
193 | }
194 |
195 | .cover-fill, .cover-empty {
196 | display:inline-block;
197 | height: 12px;
198 | }
199 | .chart {
200 | line-height: 0;
201 | }
202 | .cover-empty {
203 | background: white;
204 | }
205 | .cover-full {
206 | border-right: none !important;
207 | }
208 | pre.prettyprint {
209 | border: none !important;
210 | padding: 0 !important;
211 | margin: 0 !important;
212 | }
213 | .com { color: #999 !important; }
214 | .ignore-none { color: #999; font-weight: normal; }
215 |
216 | .wrapper {
217 | min-height: 100%;
218 | height: auto !important;
219 | height: 100%;
220 | margin: 0 auto -48px;
221 | }
222 | .footer, .push {
223 | height: 48px;
224 | }
225 |
--------------------------------------------------------------------------------
/coverage/lcov-report/block-navigation.js:
--------------------------------------------------------------------------------
1 | /* eslint-disable */
2 | var jumpToCode = (function init() {
3 | // Classes of code we would like to highlight in the file view
4 | var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];
5 |
6 | // Elements to highlight in the file listing view
7 | var fileListingElements = ['td.pct.low'];
8 |
9 | // We don't want to select elements that are direct descendants of another match
10 | var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `
11 |
12 | // Selecter that finds elements on the page to which we can jump
13 | var selector =
14 | fileListingElements.join(', ') +
15 | ', ' +
16 | notSelector +
17 | missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`
18 |
19 | // The NodeList of matching elements
20 | var missingCoverageElements = document.querySelectorAll(selector);
21 |
22 | var currentIndex;
23 |
24 | function toggleClass(index) {
25 | missingCoverageElements
26 | .item(currentIndex)
27 | .classList.remove('highlighted');
28 | missingCoverageElements.item(index).classList.add('highlighted');
29 | }
30 |
31 | function makeCurrent(index) {
32 | toggleClass(index);
33 | currentIndex = index;
34 | missingCoverageElements.item(index).scrollIntoView({
35 | behavior: 'smooth',
36 | block: 'center',
37 | inline: 'center'
38 | });
39 | }
40 |
41 | function goToPrevious() {
42 | var nextIndex = 0;
43 | if (typeof currentIndex !== 'number' || currentIndex === 0) {
44 | nextIndex = missingCoverageElements.length - 1;
45 | } else if (missingCoverageElements.length > 1) {
46 | nextIndex = currentIndex - 1;
47 | }
48 |
49 | makeCurrent(nextIndex);
50 | }
51 |
52 | function goToNext() {
53 | var nextIndex = 0;
54 |
55 | if (
56 | typeof currentIndex === 'number' &&
57 | currentIndex < missingCoverageElements.length - 1
58 | ) {
59 | nextIndex = currentIndex + 1;
60 | }
61 |
62 | makeCurrent(nextIndex);
63 | }
64 |
65 | return function jump(event) {
66 | switch (event.which) {
67 | case 78: // n
68 | case 74: // j
69 | goToNext();
70 | break;
71 | case 66: // b
72 | case 75: // k
73 | case 80: // p
74 | goToPrevious();
75 | break;
76 | }
77 | };
78 | })();
79 | window.addEventListener('keydown', jumpToCode);
80 |
--------------------------------------------------------------------------------
/coverage/lcov-report/component-did-catch.js.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Code coverage report for component-did-catch.js
7 |
8 |
9 |
10 |
11 |
12 |
17 |
18 |
19 |
20 |
21 |
22 |
All files component-did-catch.js
23 |
24 |
25 |
26 | 100%
27 | Statements
28 | 9/9
29 |
30 |
31 |
32 |
33 | 100%
34 | Branches
35 | 4/4
36 |
37 |
38 |
39 |
40 | 100%
41 | Functions
42 | 5/5
43 |
44 |
45 |
46 |
47 | 100%
48 | Lines
49 | 8/8
50 |
51 |
52 |
53 |
54 |
55 | Press n or j to go to the next uncovered block, b , p or k for the previous block.
56 |
57 |
58 |
59 |
60 | 1
61 | 2
62 | 3
63 | 4
64 | 5
65 | 6
66 | 7
67 | 8
68 | 9
69 | 10
70 | 11
71 | 12
72 | 13
73 | 14
74 | 15
75 | 16
76 | 17
77 | 18
78 | 19
79 | 20
80 | 21
81 | 22
82 | 23
83 | 24
84 | 25
85 | 26
86 | 27
87 | 28
88 | 29
89 | 30
90 | 31
91 | 32
92 | 33
93 | 34
94 | 35
95 | 36
96 | 37
97 | 38
98 | 39
99 | 40
100 | 41
101 | 42
102 | 43
103 | 44
104 | 45
105 | 46
106 |
107 |
108 |
109 | 1x
110 |
111 | 1x
112 | 1x
113 |
114 |
115 | 3x
116 |
117 |
118 |
119 |
120 |
121 |
122 |
123 |
124 |
125 | 2x
126 |
127 |
128 |
129 |
130 | 1x
131 | 1x
132 |
133 | 2x
134 |
135 |
136 |
137 |
138 |
139 |
140 |
141 |
142 |
143 |
144 |
145 |
146 |
147 |
148 |
149 |
150 | import * as React from 'react'
151 | import {reportError} from './utils'
152 |
153 | class ErrorBoundary extends React.Component {
154 | state = {hasError: false}
155 | componentDidCatch(error, info) {
156 | this.setState({hasError: true})
157 | reportError(error, info)
158 | }
159 | render() {
160 | return this.state.hasError ? (
161 | <div>There was a problem</div>
162 | ) : (
163 | this.props.children
164 | )
165 | }
166 | }
167 |
168 | class Bomb extends React.Component {
169 | render() {
170 | return this['💣'].caboom()
171 | }
172 | }
173 |
174 | class BombButton extends React.Component {
175 | state = {renderBomb: false}
176 | handleBombClick = () => this.setState({renderBomb: true})
177 | render() {
178 | return (
179 | <ErrorBoundary>
180 | {this.state.renderBomb ? (
181 | <Bomb />
182 | ) : (
183 | <button onClick={this.handleBombClick}>
184 | <span role="img" aria-label="bomb">
185 | 💣
186 | </span>
187 | </button>
188 | )}
189 | </ErrorBoundary>
190 | )
191 | }
192 | }
193 |
194 | export {BombButton}
195 |
196 |
197 |
198 |
199 |
204 |
205 |
206 |
211 |
212 |
213 |
214 |
215 |
--------------------------------------------------------------------------------
/coverage/lcov-report/favicon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/kentcdodds/react-testing-library-examples/def00171bc999e00bc4f75ffa15e6db9754ad854/coverage/lcov-report/favicon.png
--------------------------------------------------------------------------------
/coverage/lcov-report/fetch-greeting.js.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Code coverage report for fetch-greeting.js
7 |
8 |
9 |
10 |
11 |
12 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 | 93.75%
27 | Statements
28 | 15/16
29 |
30 |
31 |
32 |
33 | 88.89%
34 | Branches
35 | 8/9
36 |
37 |
38 |
39 |
40 | 100%
41 | Functions
42 | 5/5
43 |
44 |
45 |
46 |
47 | 93.75%
48 | Lines
49 | 15/16
50 |
51 |
52 |
53 |
54 |
55 | Press n or j to go to the next uncovered block, b , p or k for the previous block.
56 |
57 |
58 |
59 |
60 | 1
61 | 2
62 | 3
63 | 4
64 | 5
65 | 6
66 | 7
67 | 8
68 | 9
69 | 10
70 | 11
71 | 12
72 | 13
73 | 14
74 | 15
75 | 16
76 | 17
77 | 18
78 | 19
79 | 20
80 | 21
81 | 22
82 | 23
83 | 24
84 | 25
85 | 26
86 | 27
87 | 28
88 | 29
89 | 30
90 | 31
91 | 32
92 | 33
93 | 34
94 | 35
95 | 36
96 | 37
97 | 38
98 | 39
99 | 40
100 | 41
101 | 42
102 | 43
103 | 44
104 | 45
105 | 46
106 | 47
107 | 48
108 | 49
109 | 50
110 | 51
111 | 52
112 | 53
113 | 54
114 | 55
115 | 56
116 | 57
117 | 58
118 | 59
119 | 60
120 | 61
121 | 62
122 | 63
123 | 64
124 | 65
125 |
126 |
127 |
128 | 1x
129 |
130 |
131 |
132 |
133 |
134 | 2x
135 |
136 | 1x
137 |
138 |
139 |
140 |
141 |
142 | 1x
143 |
144 |
145 |
146 |
147 |
148 |
149 |
150 |
151 |
152 |
153 |
154 | 5x
155 |
156 |
157 |
158 | 5x
159 |
160 | 5x
161 | 2x
162 |
163 |
164 | 1x
165 | 1x
166 | 1x
167 | 1x
168 |
169 |
170 | 1x
171 |
172 |
173 |
174 | 5x
175 |
176 | 5x
177 |
178 |
179 |
180 |
181 |
182 |
183 |
184 |
185 |
186 |
187 |
188 | import * as React from 'react'
189 | import {useState, useReducer} from 'react'
190 | import axios from 'axios'
191 |
192 | const initialState = {
193 | error: null,
194 | greeting: null,
195 | }
196 |
197 | function greetingReducer(state, action) {
198 | switch (action.type) {
199 | case 'SUCCESS': {
200 | return {
201 | error: null,
202 | greeting: action.greeting,
203 | }
204 | }
205 | case 'ERROR': {
206 | return {
207 | error: action.error,
208 | greeting: null,
209 | }
210 | }
211 | default: {
212 | return state
213 | }
214 | }
215 | }
216 |
217 | function FetchGreeting() {
218 | const [{error, greeting}, dispatch] = useReducer(
219 | greetingReducer,
220 | initialState,
221 | )
222 | const [buttonClicked, setButtonClicked] = useState(false)
223 |
224 | const fetchGreeting = async () => {
225 | axios
226 | .get('/greeting')
227 | .then((response) => {
228 | const {data} = response
229 | const {greeting} = data
230 | dispatch({type: 'SUCCESS', greeting})
231 | setButtonClicked(true)
232 | })
233 | .catch((error) => {
234 | dispatch({type: 'ERROR', error})
235 | })
236 | }
237 |
238 | const buttonText = buttonClicked ? 'Ok' : 'Load Greeting'
239 |
240 | return (
241 | <div>
242 | <button onClick={fetchGreeting} disabled={buttonClicked}>
243 | {buttonText}
244 | </button>
245 | {greeting && <h1>{greeting}</h1>}
246 | {error && <p role="alert">Oops, failed to fetch!</p>}
247 | </div>
248 | )
249 | }
250 |
251 | export {FetchGreeting}
252 |
253 |
254 |
255 |
256 |
261 |
262 |
263 |
268 |
269 |
270 |
271 |
272 |
--------------------------------------------------------------------------------
/coverage/lcov-report/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Code coverage report for All files
7 |
8 |
9 |
10 |
11 |
12 |
17 |
18 |
19 |
20 |
21 |
22 |
All files
23 |
24 |
25 |
26 | 88.89%
27 | Statements
28 | 32/36
29 |
30 |
31 |
32 |
33 | 92.31%
34 | Branches
35 | 12/13
36 |
37 |
38 |
39 |
40 | 87.5%
41 | Functions
42 | 14/16
43 |
44 |
45 |
46 |
47 | 88.57%
48 | Lines
49 | 31/35
50 |
51 |
52 |
53 |
54 |
55 | Press n or j to go to the next uncovered block, b , p or k for the previous block.
56 |
57 |
58 |
59 |
60 |
61 |
62 |
63 | File
64 |
65 | Statements
66 |
67 | Branches
68 |
69 | Functions
70 |
71 | Lines
72 |
73 |
74 |
75 |
76 | component-did-catch.js
77 |
78 |
79 |
80 | 100%
81 | 9/9
82 | 100%
83 | 4/4
84 | 100%
85 | 5/5
86 | 100%
87 | 8/8
88 |
89 |
90 |
91 | fetch-greeting.js
92 |
93 |
94 |
95 | 93.75%
96 | 15/16
97 | 88.89%
98 | 8/9
99 | 100%
100 | 5/5
101 | 93.75%
102 | 15/16
103 |
104 |
105 |
106 | index.js
107 |
108 |
109 |
110 | 0%
111 | 0/2
112 | 100%
113 | 0/0
114 | 0%
115 | 0/1
116 | 0%
117 | 0/2
118 |
119 |
120 |
121 | lazy-component.js
122 |
123 |
124 |
125 | 100%
126 | 1/1
127 | 100%
128 | 0/0
129 | 100%
130 | 1/1
131 | 100%
132 | 1/1
133 |
134 |
135 |
136 | react-context.js
137 |
138 |
139 |
140 | 100%
141 | 7/7
142 | 100%
143 | 0/0
144 | 100%
145 | 3/3
146 | 100%
147 | 7/7
148 |
149 |
150 |
151 | utils.js
152 |
153 |
154 |
155 | 0%
156 | 0/1
157 | 100%
158 | 0/0
159 | 0%
160 | 0/1
161 | 0%
162 | 0/1
163 |
164 |
165 |
166 |
167 |
168 |
169 |
170 |
175 |
176 |
177 |
182 |
183 |
184 |
185 |
186 |
--------------------------------------------------------------------------------
/coverage/lcov-report/index.js.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Code coverage report for index.js
7 |
8 |
9 |
10 |
11 |
12 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 | 0%
27 | Statements
28 | 0/2
29 |
30 |
31 |
32 |
33 | 100%
34 | Branches
35 | 0/0
36 |
37 |
38 |
39 |
40 | 0%
41 | Functions
42 | 0/1
43 |
44 |
45 |
46 |
47 | 0%
48 | Lines
49 | 0/2
50 |
51 |
52 |
53 |
54 |
55 | Press n or j to go to the next uncovered block, b , p or k for the previous block.
56 |
57 |
58 |
59 |
60 | 1
61 | 2
62 | 3
63 | 4
64 | 5
65 | 6
66 | 7
67 | 8
68 | 9
69 | 10
70 | 11
71 | 12
72 | 13
73 | 14
74 | 15
75 | 16
76 | 17
77 | 18
78 | 19
79 | 20
80 | 21
81 | 22
82 | 23
83 | 24
84 | 25
85 | 26
86 | 27
87 | 28
88 | 29
89 | 30
90 | 31
91 | 32
92 | 33
93 | 34
94 | 35
95 | 36
96 | 37
97 | 38
98 | 39
99 | 40
100 | 41
101 | 42
102 |
103 |
104 |
105 |
106 |
107 |
108 |
109 |
110 |
111 |
112 |
113 |
114 |
115 |
116 |
117 |
118 |
119 |
120 |
121 |
122 |
123 |
124 |
125 |
126 |
127 |
128 |
129 |
130 |
131 |
132 |
133 |
134 |
135 |
136 |
137 |
138 |
139 |
140 |
141 |
142 | import * as React from 'react'
143 | import {render} from 'react-dom'
144 |
145 | function App( ) {
146 | return (
147 | <div>
148 | <h1>
149 | react-testing-library examples{' '}
150 | <span role="img" aria-label="goat">
151 | 🐐
152 | </span>
153 | </h1>
154 | <div>
155 | <p>{`
156 | This is an example project of how to test react components using
157 | react-testing-library and Jest. The idea is that most of the tests
158 | should be runnable in codesandbox to make it easy to try things out,
159 | fork, contribute, etc. However, there will be some tests which do not
160 | work in codesandbox and we'll put those in a special folder called
161 | __local_tests__. Locally (and in CI) all tests are run via the "test"
162 | script, in codesandbox only the tests in __tests__ will be run.
163 | If you can make it work in codesandbox then do because it's a lot
164 | easier for people to tinker with things in codesandbox.
165 | `}</p>
166 | <p>
167 | <a href="https://codesandbox.io/s/github/kentcdodds/react-testing-library-examples">
168 | Open this in codesandbox
169 | </a>{' '}
170 | to play around with things. You can also use the codesandbox to
171 | contribute to{' '}
172 | <a href="https://github.com/kentcdodds/react-testing-library-examples">
173 | the project on GitHub
174 | </a>
175 | !
176 | </p>
177 | </div>
178 | </div>
179 | )
180 | }
181 |
182 | render(<App />, document.getElementById('root'))
183 |
184 |
185 |
186 |
187 |
192 |
193 |
194 |
199 |
200 |
201 |
202 |
203 |
--------------------------------------------------------------------------------
/coverage/lcov-report/lazy-component.js.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Code coverage report for lazy-component.js
7 |
8 |
9 |
10 |
11 |
12 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 | 100%
27 | Statements
28 | 1/1
29 |
30 |
31 |
32 |
33 | 100%
34 | Branches
35 | 0/0
36 |
37 |
38 |
39 |
40 | 100%
41 | Functions
42 | 1/1
43 |
44 |
45 |
46 |
47 | 100%
48 | Lines
49 | 1/1
50 |
51 |
52 |
53 |
54 |
55 | Press n or j to go to the next uncovered block, b , p or k for the previous block.
56 |
57 |
58 |
59 |
60 | 1
61 | 2
62 | 3
63 | 4
64 | 5
65 | 6
66 | 7
67 | 8
68 |
69 |
70 | 2x
71 |
72 |
73 |
74 | import * as React from 'react'
75 |
76 | function LazyComponent() {
77 | return <div>I am lazy!</div>
78 | }
79 |
80 | export default LazyComponent
81 |
82 |
83 |
84 |
85 |
90 |
91 |
92 |
97 |
98 |
99 |
100 |
101 |
--------------------------------------------------------------------------------
/coverage/lcov-report/prettify.css:
--------------------------------------------------------------------------------
1 | .pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee}
2 |
--------------------------------------------------------------------------------
/coverage/lcov-report/prettify.js:
--------------------------------------------------------------------------------
1 | /* eslint-disable */
2 | window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;arat[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^
125 |
130 |
131 |
132 |