@api-client/core 0.14.10 → 0.15.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/RELEASE.md +163 -0
  2. package/RELEASE_SETUP.md +235 -0
  3. package/build/src/events/authorization/AuthorizationEvents.d.ts +1 -1
  4. package/build/src/events/authorization/AuthorizationEvents.d.ts.map +1 -1
  5. package/build/src/events/authorization/AuthorizationEvents.js +1 -1
  6. package/build/src/events/authorization/AuthorizationEvents.js.map +1 -1
  7. package/build/src/events/cookies/CookieEvents.d.ts +1 -1
  8. package/build/src/events/cookies/CookieEvents.d.ts.map +1 -1
  9. package/build/src/events/cookies/CookieEvents.js +1 -1
  10. package/build/src/events/cookies/CookieEvents.js.map +1 -1
  11. package/build/src/modeling/DomainImpactAnalysis.d.ts +22 -119
  12. package/build/src/modeling/DomainImpactAnalysis.d.ts.map +1 -1
  13. package/build/src/modeling/DomainImpactAnalysis.js +49 -155
  14. package/build/src/modeling/DomainImpactAnalysis.js.map +1 -1
  15. package/build/src/modeling/DomainValidation.d.ts +8 -0
  16. package/build/src/modeling/DomainValidation.d.ts.map +1 -0
  17. package/build/src/modeling/DomainValidation.js +99 -0
  18. package/build/src/modeling/DomainValidation.js.map +1 -0
  19. package/build/src/modeling/types.d.ts +70 -0
  20. package/build/src/modeling/types.d.ts.map +1 -1
  21. package/build/src/modeling/types.js.map +1 -1
  22. package/build/src/modeling/validation/rules.d.ts +2 -3
  23. package/build/src/modeling/validation/rules.d.ts.map +1 -1
  24. package/build/src/modeling/validation/rules.js.map +1 -1
  25. package/build/src/modeling/validation/semantic_validation.d.ts +31 -0
  26. package/build/src/modeling/validation/semantic_validation.d.ts.map +1 -0
  27. package/build/src/modeling/validation/semantic_validation.js +126 -0
  28. package/build/src/modeling/validation/semantic_validation.js.map +1 -0
  29. package/build/tsconfig.tsbuildinfo +1 -1
  30. package/noop.ts +3 -0
  31. package/package.json +9 -4
  32. package/src/events/authorization/AuthorizationEvents.ts +1 -1
  33. package/src/events/cookies/CookieEvents.ts +1 -1
  34. package/src/modeling/DomainImpactAnalysis.ts +54 -239
  35. package/src/modeling/DomainValidation.ts +105 -0
  36. package/src/modeling/types.ts +86 -0
  37. package/src/modeling/validation/rules.ts +2 -4
  38. package/src/modeling/validation/semantic_validation.ts +145 -0
  39. package/tests/unit/events/EventsTestHelpers.ts +16 -0
  40. package/tests/unit/events/amf.spec.ts +151 -0
  41. package/tests/unit/events/authorization.spec.ts +150 -0
  42. package/tests/unit/events/cookie.spec.ts +274 -0
  43. package/tests/unit/events/encryption.spec.ts +108 -0
  44. package/tests/unit/events/events_polyfills.ts +77 -0
  45. package/tests/unit/events/process.spec.ts +120 -0
  46. package/tests/unit/events/reporting.spec.ts +82 -0
  47. package/tests/unit/events/telemetry.spec.ts +224 -0
  48. package/tests/unit/events/transport.spec.ts +139 -0
  49. package/tests/unit/modeling/domain_impact_analysis.spec.ts +0 -110
  50. package/tests/unit/modeling/domain_validation.spec.ts +94 -0
  51. package/tests/unit/modeling/validation/semantic_validation.spec.ts +91 -0
  52. package/tests/unit/models/environment.spec.ts +574 -0
  53. package/tests/unit/models/error_response.spec.ts +183 -0
  54. package/tests/unit/models/headers_array.spec.ts +86 -0
  55. package/tests/unit/models/http-actions/assertion/equal_assertion.spec.ts +103 -0
  56. package/tests/unit/models/http-actions/assertion/greater_than_assertion.spec.ts +91 -0
  57. package/tests/unit/models/http-actions/assertion/includes_assertion.spec.ts +71 -0
  58. package/tests/unit/models/http-actions/assertion/less_than_assertion.spec.ts +91 -0
  59. package/tests/unit/models/http-actions/assertion/matches_assertion.spec.ts +71 -0
  60. package/tests/unit/models/http-actions/assertion/matches_schema_assertion.spec.ts +117 -0
  61. package/tests/unit/models/http-actions/assertion/not_equal_assertion.spec.ts +103 -0
  62. package/tests/unit/models/http-actions/assertion/not_includes_assertion.spec.ts +71 -0
  63. package/tests/unit/models/http-actions/assertion/not_ok_assertion.spec.ts +47 -0
  64. package/tests/unit/models/http-actions/assertion/not_to_be_assertion.spec.ts +72 -0
  65. package/tests/unit/models/http-actions/assertion/ok_assertion.spec.ts +44 -0
  66. package/tests/unit/models/http-actions/assertion/to_be_assertion.spec.ts +71 -0
  67. package/tests/unit/models/http-actions/transformation/as_lower_case_step.spec.ts +47 -0
  68. package/tests/unit/models/http-actions/transformation/as_number_step.spec.ts +47 -0
  69. package/tests/unit/models/http-actions/transformation/as_upper_case_step.spec.ts +47 -0
  70. package/tests/unit/models/http-actions/transformation/round_step.spec.ts +69 -0
  71. package/tests/unit/models/http-actions/transformation/substring_step.spec.ts +85 -0
  72. package/tests/unit/models/http-actions/transformation/trim_step.spec.ts +44 -0
  73. package/tests/unit/models/http_cookie.spec.ts +516 -0
  74. package/tests/unit/models/http_history.spec.ts +443 -0
  75. package/tests/unit/models/project_folder.spec.ts +926 -0
  76. package/tests/unit/models/project_item.spec.ts +137 -0
  77. package/tests/unit/models/project_request.spec.ts +1047 -0
  78. package/tests/unit/models/project_schema.spec.ts +236 -0
  79. package/tests/unit/models/property.spec.ts +625 -0
  80. package/tests/unit/models/provider.spec.ts +102 -0
  81. package/tests/unit/models/request.spec.ts +1206 -0
  82. package/tests/unit/models/request_log.spec.ts +308 -0
  83. package/tests/unit/models/request_time.spec.ts +138 -0
  84. package/tests/unit/models/response_redirect.spec.ts +303 -0
  85. package/tests/unit/models/sent_request.spec.ts +206 -0
  86. package/tests/unit/models/server.spec.ts +195 -0
  87. package/tests/unit/models/thing.spec.ts +154 -0
  88. package/build/oauth-popup.html +0 -33
  89. /package/tests/unit/models/{Certificate.spec.ts → certificate.spec.ts} +0 -0
  90. /package/tests/unit/models/{HostRule.spec.ts → host_rule.spec.ts} +0 -0
  91. /package/tests/unit/models/{HttpProject.spec.ts → http_project.spec.ts} +0 -0
  92. /package/tests/unit/models/{HttpRequest.spec.ts → http_request.spec.ts} +0 -0
  93. /package/tests/unit/models/{HttpResponse.spec.ts → http_response.spec.ts} +0 -0
  94. /package/tests/unit/models/{License.spec.ts → license.spec.ts} +0 -0
  95. /package/tests/unit/models/{Response.spec.ts → response.spec.ts} +0 -0
@@ -0,0 +1,1047 @@
1
+ import { test } from '@japa/runner'
2
+ import { assert } from '@esm-bundle/chai'
3
+ import { Kind as ProjectRequestKind, ProjectRequest, IProjectRequest } from '../../../src/models/ProjectRequest.js'
4
+ import { HttpProject } from '../../../src/models/HttpProject.js'
5
+ import { Kind as HttpRequestKind, IHttpRequest } from '../../../src/models/HttpRequest.js'
6
+ import { Kind as RequestLogKind, RequestLog } from '../../../src/models/RequestLog.js'
7
+ import { SentRequest } from '../../../src/models/SentRequest.js'
8
+ import { RequestConfig } from '../../../src/models/RequestConfig.js'
9
+ import { RequestAuthorization } from '../../../src/models/RequestAuthorization.js'
10
+ import { Request, Kind as RequestKind } from '../../../src/models/Request.js'
11
+ import { ProjectFolderKind, ThingKind } from '../../../src/models/kinds.js'
12
+
13
+ test.group('ProjectRequest - Default project initialization', () => {
14
+ test('initializes a default project request', () => {
15
+ const project = new HttpProject()
16
+ const result = new ProjectRequest(project)
17
+ assert.equal(result.kind, ProjectRequestKind, 'sets the kind property')
18
+ assert.typeOf(result.created, 'number', 'sets the created property')
19
+ assert.equal(result.updated, result.created, 'sets the updated property')
20
+ assert.typeOf(result.midnight, 'number', 'sets the updated property')
21
+ assert.typeOf(result.key, 'string', 'sets the key property')
22
+ assert.typeOf(result.info, 'EventTarget', 'sets the info property')
23
+ assert.typeOf(result.expects, 'object', 'sets the expects property')
24
+ assert.isUndefined(result.log, 'does not set the log property')
25
+ assert.isUndefined(result.config, 'does not set the config property')
26
+ assert.isUndefined(result.authorization, 'does not set the authorization property')
27
+ assert.isUndefined(result.flows, 'does not set the flows property')
28
+ assert.isUndefined(result.clientCertificate, 'does not set the clientCertificate property')
29
+ assert.isUndefined(result.environment, 'does not set the environment property')
30
+ })
31
+ })
32
+
33
+ test.group('ProjectRequest - From schema initialization', () => {
34
+ test('sets the kind property', () => {
35
+ const project = new HttpProject()
36
+ const base: IProjectRequest = {
37
+ kind: ProjectRequestKind,
38
+ info: { kind: ThingKind, name: '' },
39
+ key: '',
40
+ expects: { kind: HttpRequestKind, method: '', url: '' },
41
+ }
42
+ const init: IProjectRequest = { ...base }
43
+ const request = new ProjectRequest(project, init)
44
+ assert.equal(request.kind, ProjectRequestKind)
45
+ })
46
+
47
+ test('sets the key property when missing', () => {
48
+ const project = new HttpProject()
49
+ const base: IProjectRequest = {
50
+ kind: ProjectRequestKind,
51
+ info: { kind: ThingKind, name: '' },
52
+ key: '',
53
+ expects: { kind: HttpRequestKind, method: '', url: '' },
54
+ }
55
+ const init: IProjectRequest = { ...base }
56
+ // @ts-expect-error Testing missing properties
57
+ delete init.key
58
+ const request = new ProjectRequest(project, init)
59
+ assert.typeOf(request.key, 'string')
60
+ assert.isNotEmpty(request.key)
61
+ })
62
+
63
+ test('sets the key property', () => {
64
+ const project = new HttpProject()
65
+ const base: IProjectRequest = {
66
+ kind: ProjectRequestKind,
67
+ info: { kind: ThingKind, name: '' },
68
+ key: '',
69
+ expects: { kind: HttpRequestKind, method: '', url: '' },
70
+ }
71
+ const init: IProjectRequest = { ...base, key: 'test' }
72
+ const request = new ProjectRequest(project, init)
73
+ assert.equal(request.key, 'test')
74
+ })
75
+
76
+ test('sets the expects property when missing', () => {
77
+ const project = new HttpProject()
78
+ const base: IProjectRequest = {
79
+ kind: ProjectRequestKind,
80
+ info: { kind: ThingKind, name: '' },
81
+ key: '',
82
+ expects: { kind: HttpRequestKind, method: '', url: '' },
83
+ }
84
+ const init: IProjectRequest = { ...base }
85
+ // @ts-expect-error Testing missing properties
86
+ delete init.expects
87
+ const request = new ProjectRequest(project, init)
88
+ assert.typeOf(request.expects, 'object')
89
+ assert.equal(request.expects.method, 'GET')
90
+ assert.equal(request.expects.url, '')
91
+ })
92
+
93
+ test('sets the expects property', () => {
94
+ const project = new HttpProject()
95
+ const base: IProjectRequest = {
96
+ kind: ProjectRequestKind,
97
+ info: { kind: ThingKind, name: '' },
98
+ key: '',
99
+ expects: { kind: HttpRequestKind, method: '', url: '' },
100
+ }
101
+ const init: IProjectRequest = {
102
+ ...base,
103
+ expects: { kind: HttpRequestKind, url: 'test.com', method: 'GET' },
104
+ }
105
+ const request = new ProjectRequest(project, init)
106
+ assert.typeOf(request.expects, 'object')
107
+ assert.equal(request.expects.method, 'GET')
108
+ assert.equal(request.expects.url, 'test.com')
109
+ })
110
+
111
+ test('sets the info property when missing', () => {
112
+ const project = new HttpProject()
113
+ const base: IProjectRequest = {
114
+ kind: ProjectRequestKind,
115
+ info: { kind: ThingKind, name: '' },
116
+ key: '',
117
+ expects: { kind: HttpRequestKind, method: '', url: '' },
118
+ }
119
+ const init: IProjectRequest = { ...base }
120
+ // @ts-expect-error Testing missing properties
121
+ delete init.info
122
+ const request = new ProjectRequest(project, init)
123
+ assert.typeOf(request.info, 'EventTarget')
124
+ assert.equal(request.info.name, '')
125
+ })
126
+
127
+ test('sets the info property', () => {
128
+ const project = new HttpProject()
129
+ const base: IProjectRequest = {
130
+ kind: ProjectRequestKind,
131
+ info: { kind: ThingKind, name: '' },
132
+ key: '',
133
+ expects: { kind: HttpRequestKind, method: '', url: '' },
134
+ }
135
+ const init: IProjectRequest = { ...base, info: { kind: ThingKind, name: 'A request' } }
136
+ const request = new ProjectRequest(project, init)
137
+ assert.typeOf(request.info, 'EventTarget')
138
+ assert.equal(request.info.name, 'A request')
139
+ })
140
+
141
+ test('sets the log property', () => {
142
+ const project = new HttpProject()
143
+ const base: IProjectRequest = {
144
+ kind: ProjectRequestKind,
145
+ info: { kind: ThingKind, name: '' },
146
+ key: '',
147
+ expects: { kind: HttpRequestKind, method: '', url: '' },
148
+ }
149
+ const sentRequest = SentRequest.fromBaseValues({
150
+ url: 'test.com',
151
+ startTime: Date.now(),
152
+ })
153
+ const log = RequestLog.fromRequest(sentRequest.toJSON())
154
+ const init: IProjectRequest = { ...base, log: log.toJSON() }
155
+ const request = new ProjectRequest(project, init)
156
+ assert.typeOf(request.log, 'object')
157
+ assert.equal(request.log!.kind, RequestLogKind)
158
+ assert.typeOf(request.log!.request, 'object')
159
+ assert.equal(request.log!.request!.url, 'test.com')
160
+ })
161
+
162
+ test('sets the config property', () => {
163
+ const project = new HttpProject()
164
+ const base: IProjectRequest = {
165
+ kind: ProjectRequestKind,
166
+ info: { kind: ThingKind, name: '' },
167
+ key: '',
168
+ expects: { kind: HttpRequestKind, method: '', url: '' },
169
+ }
170
+ const config = RequestConfig.withDefaults()
171
+ const init: IProjectRequest = { ...base, config: config.toJSON() }
172
+ const request = new ProjectRequest(project, init)
173
+ assert.typeOf(request.config, 'object')
174
+ assert.isTrue(request.config!.enabled)
175
+ assert.equal(request.config!.timeout, 90)
176
+ })
177
+
178
+ test('sets the authorization property', () => {
179
+ const project = new HttpProject()
180
+ const base: IProjectRequest = {
181
+ kind: ProjectRequestKind,
182
+ info: { kind: ThingKind, name: '' },
183
+ key: '',
184
+ expects: { kind: HttpRequestKind, method: '', url: '' },
185
+ }
186
+ const authorization = new RequestAuthorization()
187
+ const init: IProjectRequest = { ...base, authorization: [authorization.toJSON()] }
188
+ const request = new ProjectRequest(project, init)
189
+ assert.typeOf(request.authorization, 'array')
190
+ assert.lengthOf(request.authorization!, 1)
191
+ })
192
+
193
+ test('sets the created property', () => {
194
+ const project = new HttpProject()
195
+ const base: IProjectRequest = {
196
+ kind: ProjectRequestKind,
197
+ info: { kind: ThingKind, name: '' },
198
+ key: '',
199
+ expects: { kind: HttpRequestKind, method: '', url: '' },
200
+ }
201
+ const init: IProjectRequest = { ...base, created: 123 }
202
+ const request = new ProjectRequest(project, init)
203
+ assert.equal(request.created, 123)
204
+ })
205
+
206
+ test('sets the default created property', () => {
207
+ const project = new HttpProject()
208
+ const base: IProjectRequest = {
209
+ kind: ProjectRequestKind,
210
+ info: { kind: ThingKind, name: '' },
211
+ key: '',
212
+ expects: { kind: HttpRequestKind, method: '', url: '' },
213
+ }
214
+ const init: IProjectRequest = { ...base }
215
+ const request = new ProjectRequest(project, init)
216
+ assert.typeOf(request.created, 'number')
217
+ })
218
+
219
+ test('sets the updated property', () => {
220
+ const project = new HttpProject()
221
+ const base: IProjectRequest = {
222
+ kind: ProjectRequestKind,
223
+ info: { kind: ThingKind, name: '' },
224
+ key: '',
225
+ expects: { kind: HttpRequestKind, method: '', url: '' },
226
+ }
227
+ const init: IProjectRequest = { ...base, updated: 123 }
228
+ const request = new ProjectRequest(project, init)
229
+ assert.equal(request.updated, 123)
230
+ })
231
+
232
+ test('sets the default updated property', () => {
233
+ const project = new HttpProject()
234
+ const base: IProjectRequest = {
235
+ kind: ProjectRequestKind,
236
+ info: { kind: ThingKind, name: '' },
237
+ key: '',
238
+ expects: { kind: HttpRequestKind, method: '', url: '' },
239
+ }
240
+ const init: IProjectRequest = { ...base }
241
+ const request = new ProjectRequest(project, init)
242
+ assert.equal(request.updated, request.created)
243
+ })
244
+
245
+ test('sets the midnight property', () => {
246
+ const project = new HttpProject()
247
+ const base: IProjectRequest = {
248
+ kind: ProjectRequestKind,
249
+ info: { kind: ThingKind, name: '' },
250
+ key: '',
251
+ expects: { kind: HttpRequestKind, method: '', url: '' },
252
+ }
253
+ const init: IProjectRequest = { ...base, midnight: 123 }
254
+ const request = new ProjectRequest(project, init)
255
+ assert.equal(request.midnight, 123)
256
+ })
257
+
258
+ test('sets the default midnight property', () => {
259
+ const project = new HttpProject()
260
+ const base: IProjectRequest = {
261
+ kind: ProjectRequestKind,
262
+ info: { kind: ThingKind, name: '' },
263
+ key: '',
264
+ expects: { kind: HttpRequestKind, method: '', url: '' },
265
+ }
266
+ const now = new Date()
267
+ const init: IProjectRequest = { ...base, updated: now.getTime() }
268
+ const request = new ProjectRequest(project, init)
269
+ now.setHours(0, 0, 0, 0)
270
+ assert.equal(request.midnight, now.getTime())
271
+ })
272
+
273
+ test('sets the environment property', () => {
274
+ const project = new HttpProject()
275
+ const base: IProjectRequest = {
276
+ kind: ProjectRequestKind,
277
+ info: { kind: ThingKind, name: '' },
278
+ key: '',
279
+ expects: { kind: HttpRequestKind, method: '', url: '' },
280
+ }
281
+ const env = project.addEnvironment('test')
282
+ const init: IProjectRequest = { ...base, environment: env.key }
283
+ const request = new ProjectRequest(project, init)
284
+ assert.equal(request.environment, env.key)
285
+ })
286
+ })
287
+
288
+ test.group('ProjectRequest - From JSON string initialization', () => {
289
+ test('restores project data from JSON string', () => {
290
+ const project = new HttpProject()
291
+ const request = project.addRequest('https://api.com')
292
+ request.environment = 'test'
293
+ const str = JSON.stringify(request)
294
+
295
+ const result = new ProjectRequest(project, str)
296
+
297
+ assert.equal(result.key, request.key, 'restores the key')
298
+ assert.equal(result.info.name, 'https://api.com', 'restores the info object')
299
+ assert.equal(result.expects.url, 'https://api.com', 'restores the expects object')
300
+ assert.equal(result.environment, 'test', 'restores the environment object')
301
+ })
302
+ })
303
+
304
+ test.group('ProjectRequest.fromUrl()', () => {
305
+ test('sets the request values', () => {
306
+ const url = 'https://api.com'
307
+ const project = new HttpProject()
308
+ const request = ProjectRequest.fromUrl(url, project)
309
+ const { expects } = request
310
+ assert.equal(expects.url, url, 'sets the url')
311
+ assert.equal(expects.kind, HttpRequestKind, 'sets the kind')
312
+ assert.equal(expects.method, 'GET', 'sets the HTTP method')
313
+ })
314
+
315
+ test('sets the info values', () => {
316
+ const url = 'https://api.com'
317
+ const project = new HttpProject()
318
+ const request = ProjectRequest.fromUrl(url, project)
319
+ const { info } = request
320
+ assert.equal(info.name, url, 'sets the name')
321
+ assert.equal(info.kind, ThingKind, 'sets the kind')
322
+ })
323
+
324
+ test('sets request meta', () => {
325
+ const url = 'https://api.com'
326
+ const project = new HttpProject()
327
+ const request = ProjectRequest.fromUrl(url, project)
328
+ assert.typeOf(request.key, 'string', 'has the key')
329
+ assert.equal(request.kind, ProjectRequestKind, 'sets the kind')
330
+ assert.typeOf(request.created, 'number', 'sets the created')
331
+ assert.equal(request.updated, request.created, 'sets the updated')
332
+ })
333
+
334
+ test('throws when the project is missing', () => {
335
+ const url = 'https://api.com'
336
+ assert.throws(() => {
337
+ ProjectRequest.fromUrl(url)
338
+ }, 'The project is required.')
339
+ })
340
+ })
341
+
342
+ test.group('ProjectRequest.fromName()', () => {
343
+ test('sets the request values', () => {
344
+ const name = 'a request'
345
+ const project = new HttpProject()
346
+ const request = ProjectRequest.fromName(name, project)
347
+ const { expects } = request
348
+ assert.equal(expects.url, '', 'sets the empty url')
349
+ assert.equal(expects.kind, HttpRequestKind, 'sets the kind')
350
+ assert.equal(expects.method, 'GET', 'sets the HTTP method')
351
+ })
352
+
353
+ test('sets the info values', () => {
354
+ const name = 'a request'
355
+ const project = new HttpProject()
356
+ const request = ProjectRequest.fromName(name, project)
357
+ const { info } = request
358
+ assert.equal(info.name, name, 'sets the name')
359
+ assert.equal(info.kind, ThingKind, 'sets the kind')
360
+ })
361
+
362
+ test('sets request meta', () => {
363
+ const name = 'a request'
364
+ const project = new HttpProject()
365
+ const request = ProjectRequest.fromName(name, project)
366
+ assert.typeOf(request.key, 'string', 'has the key')
367
+ assert.equal(request.kind, ProjectRequestKind, 'sets the kind')
368
+ assert.typeOf(request.created, 'number', 'sets the created')
369
+ assert.equal(request.updated, request.created, 'sets the updated')
370
+ })
371
+
372
+ test('throws when the project is missing', () => {
373
+ const name = 'a request'
374
+ assert.throws(() => {
375
+ ProjectRequest.fromName(name)
376
+ }, 'The project is required.')
377
+ })
378
+ })
379
+
380
+ test.group('ProjectRequest.fromHttpRequest()', () => {
381
+ test('sets the request values', () => {
382
+ const project = new HttpProject()
383
+ const iRequest: IHttpRequest = {
384
+ kind: HttpRequestKind,
385
+ method: 'PUT',
386
+ url: 'https://api.com',
387
+ headers: 'x-test: true',
388
+ payload: 'something',
389
+ }
390
+ const request = ProjectRequest.fromHttpRequest(iRequest, project)
391
+ const { expects } = request
392
+ assert.equal(expects.url, iRequest.url, 'sets the empty url')
393
+ assert.equal(expects.kind, HttpRequestKind, 'sets the kind')
394
+ assert.equal(expects.method, iRequest.method, 'sets the HTTP method')
395
+ assert.equal(expects.headers, iRequest.headers, 'sets the headers')
396
+ assert.equal(expects.payload, iRequest.payload, 'sets the payload')
397
+ })
398
+
399
+ test('sets the info values', () => {
400
+ const project = new HttpProject()
401
+ const iRequest: IHttpRequest = {
402
+ kind: HttpRequestKind,
403
+ method: 'PUT',
404
+ url: 'https://api.com',
405
+ headers: 'x-test: true',
406
+ payload: 'something',
407
+ }
408
+ const request = ProjectRequest.fromHttpRequest(iRequest, project)
409
+ const { info } = request
410
+ assert.equal(info.name, iRequest.url, 'sets the name')
411
+ assert.equal(info.kind, ThingKind, 'sets the kind')
412
+ })
413
+
414
+ test('sets request meta', () => {
415
+ const project = new HttpProject()
416
+ const iRequest: IHttpRequest = {
417
+ kind: HttpRequestKind,
418
+ method: 'PUT',
419
+ url: 'https://api.com',
420
+ headers: 'x-test: true',
421
+ payload: 'something',
422
+ }
423
+ const request = ProjectRequest.fromHttpRequest(iRequest, project)
424
+ assert.typeOf(request.key, 'string', 'has the key')
425
+ assert.equal(request.kind, ProjectRequestKind, 'sets the kind')
426
+ assert.typeOf(request.created, 'number', 'sets the created')
427
+ assert.equal(request.updated, request.created, 'sets the updated')
428
+ })
429
+
430
+ test('throws when the project is missing', () => {
431
+ const iRequest: IHttpRequest = {
432
+ kind: HttpRequestKind,
433
+ method: 'PUT',
434
+ url: 'https://api.com',
435
+ headers: 'x-test: true',
436
+ payload: 'something',
437
+ }
438
+ assert.throws(() => {
439
+ ProjectRequest.fromHttpRequest(iRequest)
440
+ }, 'The project is required.')
441
+ })
442
+ })
443
+
444
+ test.group('ProjectRequest.fromRequest()', () => {
445
+ test('sets the request values', () => {
446
+ const project = new HttpProject()
447
+ const httpRequest: IHttpRequest = {
448
+ kind: RequestKind,
449
+ method: 'PUT',
450
+ url: 'https://api.com',
451
+ headers: 'x-test: true',
452
+ payload: 'something',
453
+ }
454
+ const r = Request.fromHttpRequest(httpRequest)
455
+ r.info.name = 'a name'
456
+ const iRequest = r.toJSON()
457
+ const request = ProjectRequest.fromRequest(iRequest, project)
458
+ const { expects } = request
459
+ assert.equal(expects.url, iRequest.expects.url, 'sets the empty url')
460
+ assert.equal(expects.kind, HttpRequestKind, 'sets the kind')
461
+ assert.equal(expects.method, iRequest.expects.method, 'sets the HTTP method')
462
+ assert.equal(expects.headers, iRequest.expects.headers, 'sets the headers')
463
+ assert.equal(expects.payload, iRequest.expects.payload, 'sets the payload')
464
+ })
465
+
466
+ test('sets the info values', () => {
467
+ const project = new HttpProject()
468
+ const httpRequest: IHttpRequest = {
469
+ kind: RequestKind,
470
+ method: 'PUT',
471
+ url: 'https://api.com',
472
+ headers: 'x-test: true',
473
+ payload: 'something',
474
+ }
475
+ const r = Request.fromHttpRequest(httpRequest)
476
+ r.info.name = 'a name'
477
+ const iRequest = r.toJSON()
478
+ const request = ProjectRequest.fromRequest(iRequest, project)
479
+ const { info } = request
480
+ assert.equal(info.name, 'a name', 'sets the name')
481
+ assert.equal(info.kind, ThingKind, 'sets the kind')
482
+ })
483
+
484
+ test('sets request meta', () => {
485
+ const project = new HttpProject()
486
+ const httpRequest: IHttpRequest = {
487
+ kind: RequestKind,
488
+ method: 'PUT',
489
+ url: 'https://api.com',
490
+ headers: 'x-test: true',
491
+ payload: 'something',
492
+ }
493
+ const r = Request.fromHttpRequest(httpRequest)
494
+ r.info.name = 'a name'
495
+ const iRequest = r.toJSON()
496
+ const request = ProjectRequest.fromRequest(iRequest, project)
497
+ assert.typeOf(request.key, 'string', 'has the key')
498
+ assert.equal(request.kind, ProjectRequestKind, 'sets the kind')
499
+ assert.typeOf(request.created, 'number', 'sets the created')
500
+ assert.equal(request.updated, request.created, 'sets the updated')
501
+ })
502
+ })
503
+
504
+ test.group('ProjectRequest getParent()', () => {
505
+ test('returns the project object', () => {
506
+ const project = new HttpProject()
507
+ const r = project.addRequest('https://api.com')
508
+ const result = r.getParent()
509
+ assert.isTrue(result === project)
510
+ })
511
+
512
+ test('returns the folder object', () => {
513
+ const project = new HttpProject()
514
+ const folder = project.addFolder('a folder')
515
+ const r = folder.addRequest('https://api.com')
516
+ const result = r.getParent()
517
+ assert.isTrue(result === folder)
518
+ })
519
+ })
520
+
521
+ test.group('ProjectRequest getProject()', () => {
522
+ test('returns the project when added to the project', () => {
523
+ const project = new HttpProject()
524
+ const r = project.addRequest('https://api.com')
525
+ const result = r.getProject()
526
+ assert.isTrue(result === project)
527
+ })
528
+
529
+ test('returns the project when added to a folder', () => {
530
+ const project = new HttpProject()
531
+ const folder = project.addFolder('a folder')
532
+ const r = folder.addRequest('https://api.com')
533
+ const result = r.getProject()
534
+ assert.isTrue(result === project)
535
+ })
536
+ })
537
+
538
+ test.group('ProjectRequest remove()', () => {
539
+ test('removes from a project root', () => {
540
+ const project = new HttpProject()
541
+ const r = project.addRequest('https://api.com')
542
+ r.remove()
543
+ assert.deepEqual(project.items, [])
544
+ assert.deepEqual(project.definitions.requests, [])
545
+ })
546
+
547
+ test('removes from a folder', () => {
548
+ const project = new HttpProject()
549
+ const folder = project.addFolder('a folder')
550
+ const r = folder.addRequest('https://api.com')
551
+ r.remove()
552
+ assert.deepEqual(folder.items, [], 'folder has no items')
553
+ assert.lengthOf(project.items, 1, 'projects has a single item')
554
+ assert.lengthOf(
555
+ project.items.filter((i) => i.kind === ProjectFolderKind),
556
+ 1,
557
+ 'projects has only folder items'
558
+ )
559
+ assert.lengthOf(project.definitions.requests, 0, 'projects has no request definitions')
560
+ })
561
+ })
562
+
563
+ test.group('ProjectRequest clone() - project root', () => {
564
+ test('clones with defaults from a project root', () => {
565
+ const project = new HttpProject()
566
+ const r = project.addRequest('https://api.com')
567
+ const result = r.clone()
568
+ assert.typeOf(result.key, 'string', 'has the key')
569
+ assert.notEqual(result.key, r.key, 'has a different key')
570
+ assert.lengthOf(project.items, 2, 'project has a new item')
571
+ assert.isTrue(
572
+ project.items.some((i) => i.key === result.key),
573
+ 'the project has the new item'
574
+ )
575
+ assert.lengthOf(project.definitions.requests, 2, 'project has a new definition')
576
+ assert.isTrue(
577
+ project.definitions.requests.some((i) => i.key === result.key),
578
+ 'the project has the new definition'
579
+ )
580
+ })
581
+
582
+ test('does not change the key', () => {
583
+ const project = new HttpProject()
584
+ const r = project.addRequest('https://api.com')
585
+ const result = r.clone({ withoutRevalidate: true })
586
+ assert.equal(result.key, r.key)
587
+ })
588
+
589
+ test('does not attach to the project', () => {
590
+ const project = new HttpProject()
591
+ const r = project.addRequest('https://api.com')
592
+ const result = r.clone({ withoutAttach: true })
593
+
594
+ assert.lengthOf(project.items, 1, 'project has no new items')
595
+ assert.isFalse(
596
+ project.items.some((i) => i.key === result.key),
597
+ 'the project has the new item'
598
+ )
599
+ assert.lengthOf(project.definitions.requests, 1, 'project has no new definitions')
600
+ assert.isFalse(
601
+ project.definitions.requests.some((i) => i.key === result.key),
602
+ 'the project has no new definitions'
603
+ )
604
+ })
605
+
606
+ test('copies a request from one project to another', () => {
607
+ const project = new HttpProject()
608
+ const r = project.addRequest('https://api.com')
609
+ const result = r.clone({ withoutAttach: true })
610
+ const target = new HttpProject()
611
+ target.addRequest(result)
612
+ assert.isTrue(result.getProject() === target, 'the request has a new project')
613
+ assert.lengthOf(target.items, 1)
614
+ assert.lengthOf(target.definitions.requests, 1)
615
+ })
616
+ })
617
+
618
+ test.group('ProjectRequest clone() - folder root', () => {
619
+ test('clones with defaults from a folder root', () => {
620
+ const project = new HttpProject()
621
+ const folder = project.addFolder('a folder')
622
+ const request = folder.addRequest('https://api.com')
623
+ const result = request.clone()
624
+ assert.typeOf(result.key, 'string', 'has the key')
625
+ assert.notEqual(result.key, request.key, 'has a different key')
626
+ assert.lengthOf(project.items, 1, 'project has still a single item')
627
+ assert.lengthOf(folder.items, 2, 'folder has a new item')
628
+ assert.isTrue(
629
+ folder.items.some((i) => i.key === result.key),
630
+ 'the folder has the new item'
631
+ )
632
+ assert.lengthOf(project.definitions.requests, 2, 'project has a new definition')
633
+ assert.isTrue(
634
+ project.definitions.requests.some((i) => i.key === result.key),
635
+ 'the project has the new definition'
636
+ )
637
+ })
638
+
639
+ test('copies a request from one project to another', () => {
640
+ const project = new HttpProject()
641
+ const folder = project.addFolder('a folder')
642
+ const request = folder.addRequest('https://api.com')
643
+ const result = request.clone({ withoutAttach: true })
644
+ const target = new HttpProject()
645
+ target.addRequest(result)
646
+ assert.isTrue(result.getProject() === target, 'the request has a new project')
647
+ assert.lengthOf(target.items, 1)
648
+ assert.lengthOf(target.definitions.requests, 1)
649
+ })
650
+ })
651
+
652
+ test.group('ProjectRequest.clone()', () => {
653
+ test('clones the request', () => {
654
+ const project = new HttpProject()
655
+ const request = project.addRequest('https://api.com')
656
+ const result = ProjectRequest.clone(request.toJSON(), project)
657
+
658
+ assert.typeOf(result.key, 'string', 'has the key')
659
+ assert.notEqual(result.key, request.key, 'has a different key')
660
+ assert.lengthOf(project.items, 2, 'project has a new item')
661
+ assert.isTrue(
662
+ project.items.some((i) => i.key === result.key),
663
+ 'the project has the new item'
664
+ )
665
+ assert.lengthOf(project.definitions.requests, 2, 'project has a new definition')
666
+ assert.isTrue(
667
+ project.definitions.requests.some((i) => i.key === result.key),
668
+ 'the project has the new definition'
669
+ )
670
+ })
671
+ })
672
+
673
+ test.group('ProjectRequest getEnvironment()', () => {
674
+ test('returns project associated with the request', () => {
675
+ const project = new HttpProject()
676
+ const request = project.addRequest('https://api.com')
677
+ const env = project.addEnvironment('test')
678
+ request.environment = env.key
679
+ const result = request.getEnvironment()
680
+ assert.equal(result, env)
681
+ })
682
+
683
+ test('returns undefined when unknown key', () => {
684
+ const project = new HttpProject()
685
+ const request = project.addRequest('https://api.com')
686
+ project.addEnvironment('test')
687
+ request.environment = 'test'
688
+ const result = request.getEnvironment()
689
+ assert.isUndefined(result)
690
+ })
691
+
692
+ test('returns undefined when no key', () => {
693
+ const project = new HttpProject()
694
+ const request = project.addRequest('https://api.com')
695
+ const result = request.getEnvironment()
696
+ assert.isUndefined(result)
697
+ })
698
+ })
699
+
700
+ test.group('ProjectRequest readEnvironments()', () => {
701
+ test('returns the list for root environments', () => {
702
+ const project = new HttpProject()
703
+ const request = project.addRequest('https://api.com')
704
+ const env = project.addEnvironment('test')
705
+ const result = request.readEnvironments()
706
+ assert.deepEqual(result, [env])
707
+ })
708
+
709
+ test('returns empty array when no root environments', () => {
710
+ const project = new HttpProject()
711
+ const request = project.addRequest('https://api.com')
712
+ const result = request.readEnvironments()
713
+ assert.deepEqual(result, [])
714
+ })
715
+
716
+ test('returns empty array when no folder environments', () => {
717
+ const project = new HttpProject()
718
+ const f1 = project.addFolder('f1')
719
+ const r1 = f1.addRequest('r1')
720
+ const result = r1.readEnvironments()
721
+ assert.deepEqual(result, [])
722
+ })
723
+
724
+ test('returns folder environments', () => {
725
+ const project = new HttpProject()
726
+ const f1 = project.addFolder('f1')
727
+ const env = f1.addEnvironment('test')
728
+ const r1 = f1.addRequest('r1')
729
+ const result = r1.readEnvironments()
730
+ assert.deepEqual(result, [env])
731
+ })
732
+
733
+ test('returns folder and root environments', () => {
734
+ const project = new HttpProject()
735
+ const f1 = project.addFolder('f1')
736
+ const e1 = f1.addEnvironment('e1')
737
+ const e2 = project.addEnvironment('e2')
738
+ const r1 = f1.addRequest('r1')
739
+ const result = r1.readEnvironments()
740
+ assert.deepEqual(result, [e2, e1])
741
+ })
742
+ })
743
+
744
+ test.group('ProjectRequest readUrl()', () => {
745
+ test('reads the URL from the request only when no environments and default options', () => {
746
+ const project = new HttpProject()
747
+ const request = project.addRequest('https://api.com/v1/endpoint')
748
+ const result = request.readUrl()
749
+ assert.equal(result, request.expects.url)
750
+ })
751
+
752
+ test('returns undefined when no environments and baseUrl option', () => {
753
+ const project = new HttpProject()
754
+ const request = project.addRequest('https://api.com/v1/endpoint')
755
+ const result = request.readUrl({ baseUrl: true })
756
+ assert.isUndefined(result)
757
+ })
758
+
759
+ test('returns URL when no variables option is set', () => {
760
+ const project = new HttpProject()
761
+ const request = project.addRequest('https://api.com/v1/{endpoint}')
762
+ const result = request.readUrl({ noVariables: true })
763
+ assert.equal(result, 'https://api.com/v1/{endpoint}')
764
+ })
765
+
766
+ test('applies variables from a single environment', () => {
767
+ const project = new HttpProject()
768
+ const e1 = project.addEnvironment('e1')
769
+ e1.addVariable('var1', 'test')
770
+ const request = project.addRequest('https://api.com/v1/{?var1}')
771
+ const result = request.readUrl()
772
+ assert.equal(result, 'https://api.com/v1/?var1=test')
773
+ })
774
+
775
+ test('does not apply base URL to an absolute URL', () => {
776
+ const project = new HttpProject()
777
+ const e1 = project.addEnvironment('e1')
778
+ e1.addServer('http://base.com')
779
+ const request = project.addRequest('https://api.com/v1/endpoint')
780
+ const result = request.readUrl()
781
+ assert.equal(result, request.expects.url)
782
+ })
783
+
784
+ test('adds base URL to a relative URL', () => {
785
+ const project = new HttpProject()
786
+ const e1 = project.addEnvironment('e1')
787
+ e1.addServer('http://base.com')
788
+ const request = project.addRequest('/v1/endpoint')
789
+ const result = request.readUrl()
790
+ assert.equal(result, 'http://base.com/v1/endpoint')
791
+ })
792
+
793
+ test('adds base URL when there is no scheme delimiter', () => {
794
+ const project = new HttpProject()
795
+ const e1 = project.addEnvironment('e1')
796
+ e1.addServer('http://base.com/v1')
797
+ const request = project.addRequest('endpoint')
798
+ const result = request.readUrl()
799
+ assert.equal(result, 'http://base.com/v1/endpoint')
800
+ })
801
+
802
+ test('applies variables to the base URI in the server', () => {
803
+ const project = new HttpProject()
804
+ const e1 = project.addEnvironment('e1')
805
+ e1.addServer('http://{host}/v1')
806
+ e1.addVariable('host', 'base.com')
807
+ const request = project.addRequest('endpoint')
808
+ const result = request.readUrl()
809
+ assert.equal(result, 'http://base.com/v1/endpoint')
810
+ })
811
+
812
+ test('inherits variables in a folder', () => {
813
+ const project = new HttpProject()
814
+ const e1 = project.addEnvironment('e1')
815
+ e1.addServer('http://{host}/v1')
816
+ e1.addVariable('host', 'base.com')
817
+ e1.addVariable('path', 'endpoint')
818
+ const f1 = project.addFolder('f1')
819
+ const request = f1.addRequest('{path}')
820
+ const result = request.readUrl()
821
+ assert.equal(result, 'http://base.com/v1/endpoint')
822
+ })
823
+
824
+ test('mixes in inherited variables and ones defined in a folder', () => {
825
+ const project = new HttpProject()
826
+ const e1 = project.addEnvironment('e1')
827
+ e1.addServer('http://{host}/v1')
828
+ e1.addVariable('host', 'base.com')
829
+ const f1 = project.addFolder('f1')
830
+ const e2 = f1.addEnvironment('e2')
831
+ e2.addVariable('path', 'endpoint')
832
+ const request = f1.addRequest('{path}')
833
+ const result = request.readUrl()
834
+ assert.equal(result, 'http://base.com/v1/endpoint')
835
+ })
836
+
837
+ test('folder variables override parent variables', () => {
838
+ const project = new HttpProject()
839
+ const e1 = project.addEnvironment('e1')
840
+ e1.addServer('http://{host}/v1')
841
+ e1.addVariable('host', 'base.com')
842
+ e1.addVariable('path', 'other')
843
+ const f1 = project.addFolder('f1')
844
+ const e2 = f1.addEnvironment('e2')
845
+ e2.addVariable('path', 'endpoint')
846
+ const request = f1.addRequest('{path}')
847
+ const result = request.readUrl()
848
+ assert.equal(result, 'http://base.com/v1/endpoint')
849
+ })
850
+
851
+ test('folder server overrides parent server', () => {
852
+ const project = new HttpProject()
853
+ const e1 = project.addEnvironment('e1')
854
+ e1.addServer('http://{host}/v1')
855
+ e1.addVariable('host', 'base.com')
856
+ e1.addVariable('path', 'other')
857
+ const f1 = project.addFolder('f1')
858
+ const e2 = f1.addEnvironment('e2')
859
+ e2.addServer('http://alternative.pl/')
860
+ e2.addVariable('path', 'endpoint')
861
+ const request = f1.addRequest('{path}')
862
+ const result = request.readUrl()
863
+ assert.equal(result, 'http://alternative.pl/endpoint')
864
+ })
865
+
866
+ test('ignores variables when configured', () => {
867
+ const project = new HttpProject()
868
+ const e1 = project.addEnvironment('e1')
869
+ e1.addServer('http://{host}/v1')
870
+ e1.addVariable('host', 'base.com')
871
+ e1.addVariable('path', 'other')
872
+ const f1 = project.addFolder('f1')
873
+ const e2 = f1.addEnvironment('e2')
874
+ e2.addVariable('path', 'endpoint')
875
+ const request = f1.addRequest('{path}')
876
+ const result = request.readUrl({ noVariables: true })
877
+ assert.equal(result, 'http://{host}/v1/{path}')
878
+ })
879
+
880
+ test('ignores variables when configured but keeps the full server', () => {
881
+ const project = new HttpProject()
882
+ const e1 = project.addEnvironment('e1')
883
+ e1.addServer('http://{host}/v1')
884
+ e1.addVariable('host', 'base.com')
885
+ e1.addVariable('path', 'other')
886
+ const f1 = project.addFolder('f1')
887
+ const e2 = f1.addEnvironment('e2')
888
+ e2.addServer('http://alternative.pl/')
889
+ e2.addVariable('path', 'endpoint')
890
+ const request = f1.addRequest('{path}')
891
+ const result = request.readUrl({ noVariables: true })
892
+ assert.equal(result, 'http://alternative.pl/{path}')
893
+ })
894
+
895
+ test('stops searching for variables on the selected environment', () => {
896
+ const project = new HttpProject()
897
+ const e1 = project.addEnvironment('e1')
898
+ e1.addVariable('v1', 'a1')
899
+ const f1 = project.addFolder('f1')
900
+ const e2 = f1.addEnvironment('e2')
901
+ e2.addVariable('v2', 'a2')
902
+ const e3 = f1.addEnvironment('e3')
903
+ e3.addVariable('v2', 'a3')
904
+ const request = f1.addRequest('/{v1}/{v2}')
905
+ request.environment = e2.key
906
+ const result1 = request.readUrl()
907
+ assert.equal(result1, '/a1/a2')
908
+ request.environment = e3.key
909
+ const result2 = request.readUrl()
910
+ assert.equal(result2, '/a1/a3')
911
+ })
912
+
913
+ test('applies servers from a selected environment', () => {
914
+ const project = new HttpProject()
915
+ const e1 = project.addEnvironment('e1')
916
+ e1.addServer('http://first.com')
917
+ const f1 = project.addFolder('f1')
918
+ const e2 = f1.addEnvironment('e2')
919
+ e2.addServer('http://second.com')
920
+ const e3 = f1.addEnvironment('e3')
921
+ e3.addServer('http://third.com')
922
+ const request = f1.addRequest('/api')
923
+ request.environment = e2.key
924
+ const result1 = request.readUrl()
925
+ assert.equal(result1, 'http://second.com/api')
926
+ request.environment = e3.key
927
+ const result2 = request.readUrl()
928
+ assert.equal(result2, 'http://third.com/api')
929
+ })
930
+
931
+ test('returns base URI only for a folder environment', () => {
932
+ const project = new HttpProject()
933
+ const e1 = project.addEnvironment('e1')
934
+ e1.addServer('http://first.com')
935
+ const f1 = project.addFolder('f1')
936
+ const e2 = f1.addEnvironment('e2')
937
+ e2.addServer('http://second.com')
938
+ const request = f1.addRequest('/api')
939
+ const result = request.readUrl({ baseUrl: true })
940
+ assert.equal(result, 'http://second.com')
941
+ })
942
+
943
+ test('returns inherited base URI only', () => {
944
+ const project = new HttpProject()
945
+ const e1 = project.addEnvironment('e1')
946
+ e1.addServer('http://first.com')
947
+ const f1 = project.addFolder('f1')
948
+ const request = f1.addRequest('/api')
949
+ const result = request.readUrl({ baseUrl: true })
950
+ assert.equal(result, 'http://first.com')
951
+ })
952
+ })
953
+
954
+ test.group('ProjectRequest readAuthorization()', () => {
955
+ test('returns empty array when no authorization is defined', () => {
956
+ const project = new HttpProject()
957
+ const r1 = project.addRequest('r1')
958
+ const result = r1.readAuthorization()
959
+ assert.deepEqual(result, [])
960
+ })
961
+
962
+ test('returns request authorization', () => {
963
+ const project = new HttpProject()
964
+ const authorization = new RequestAuthorization()
965
+ const r1 = project.addRequest('r1')
966
+ r1.authorization = [authorization]
967
+ const result = r1.readAuthorization()
968
+ assert.deepEqual(result, [authorization])
969
+ })
970
+
971
+ test('returns environment authorization', () => {
972
+ const project = new HttpProject()
973
+ const e1 = project.addEnvironment('e1')
974
+ const authorization = new RequestAuthorization()
975
+ e1.authorization = [authorization]
976
+ const r1 = project.addRequest('r1')
977
+ r1.environment = e1.key
978
+ const result = r1.readAuthorization()
979
+ assert.deepEqual(result, [authorization])
980
+ })
981
+
982
+ test('returns request authorization and not environment authorization', () => {
983
+ const project = new HttpProject()
984
+ const e1 = project.addEnvironment('e1')
985
+ const a1 = new RequestAuthorization()
986
+ e1.authorization = [a1]
987
+ const r1 = project.addRequest('r1')
988
+ r1.environment = e1.key
989
+ const a2 = new RequestAuthorization()
990
+ r1.authorization = [a2]
991
+ const result = r1.readAuthorization()
992
+ assert.deepEqual(result, [a2])
993
+ })
994
+
995
+ test('returns inherited authorization', () => {
996
+ const project = new HttpProject()
997
+ const e1 = project.addEnvironment('e1')
998
+ const a1 = new RequestAuthorization()
999
+ e1.authorization = [a1]
1000
+ const f1 = project.addFolder('f1')
1001
+ const r1 = f1.addRequest('r1')
1002
+ const result = r1.readAuthorization()
1003
+ assert.deepEqual(result, [a1])
1004
+ })
1005
+
1006
+ test('returns first inherited authorization', () => {
1007
+ const project = new HttpProject()
1008
+ const e1 = project.addEnvironment('e1')
1009
+ const a1 = new RequestAuthorization()
1010
+ e1.authorization = [a1]
1011
+ const f1 = project.addFolder('f1')
1012
+ const e2 = f1.addEnvironment('e2')
1013
+ const a2 = new RequestAuthorization()
1014
+ e2.authorization = [a2]
1015
+ const f2 = f1.addFolder('f2')
1016
+ const r1 = f2.addRequest('r1')
1017
+ const result = r1.readAuthorization()
1018
+ assert.deepEqual(result, [a2])
1019
+ })
1020
+
1021
+ test('prohibits reading inherited authorization with encapsulated environment', () => {
1022
+ const project = new HttpProject()
1023
+ const e1 = project.addEnvironment('e1')
1024
+ const a1 = new RequestAuthorization()
1025
+ e1.authorization = [a1]
1026
+ const f1 = project.addFolder('f1')
1027
+ const e2 = f1.addEnvironment('e2')
1028
+ e2.encapsulated = true
1029
+ const f2 = f1.addFolder('f2')
1030
+ const r1 = f2.addRequest('r1')
1031
+ const result = r1.readAuthorization()
1032
+ assert.deepEqual(result, [])
1033
+ })
1034
+
1035
+ test('returns empty array when selected environment has no authorization', () => {
1036
+ const project = new HttpProject()
1037
+ const e1 = project.addEnvironment('e1')
1038
+ const a1 = new RequestAuthorization()
1039
+ e1.authorization = [a1]
1040
+ const f1 = project.addFolder('f1')
1041
+ const e2 = f1.addEnvironment('e2')
1042
+ const r1 = f1.addRequest('r1')
1043
+ r1.environment = e2.key
1044
+ const result = r1.readAuthorization()
1045
+ assert.deepEqual(result, [])
1046
+ })
1047
+ })