@api-client/ui 0.5.39 → 0.5.41
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.
- package/build/src/elements/contextual-menu/{internals/ContextualMenu.d.ts → ContextualMenu.d.ts} +11 -6
- package/build/src/elements/contextual-menu/ContextualMenu.d.ts.map +1 -0
- package/build/src/elements/contextual-menu/{internals/ContextualMenu.js → ContextualMenu.js} +25 -3
- package/build/src/elements/contextual-menu/ContextualMenu.js.map +1 -0
- package/build/src/elements/contextual-menu/internals/types.d.ts +16 -7
- package/build/src/elements/contextual-menu/internals/types.d.ts.map +1 -1
- package/build/src/elements/contextual-menu/internals/types.js.map +1 -1
- package/build/tsconfig.tsbuildinfo +1 -0
- package/package.json +1 -1
- package/src/elements/contextual-menu/{internals/ContextualMenu.ts → ContextualMenu.ts} +31 -7
- package/src/elements/contextual-menu/internals/types.ts +17 -7
- package/.aiexclude +0 -3
- package/.cursor/rules/html-and-css-best-practices.mdc +0 -63
- package/.cursor/rules/lit-best-practices.mdc +0 -89
- package/.editorconfig +0 -29
- package/.github/CONTRIBUTING.md +0 -24
- package/.github/instructions/html-and-css-best-practices.instructions.md +0 -70
- package/.github/instructions/lit-best-practices.instructions.md +0 -90
- package/.github/release.yml +0 -14
- package/.github/stale.yml +0 -23
- package/.github/workflows/auto-release.yml +0 -182
- package/.github/workflows/release.yml +0 -82
- package/.prettierrc.js +0 -14
- package/.vscode/settings.json +0 -18
- package/RELEASE.md +0 -163
- package/RELEASE_SETUP.md +0 -235
- package/build/src/demo/DemoPage.d.ts +0 -81
- package/build/src/demo/DemoPage.d.ts.map +0 -1
- package/build/src/demo/DemoPage.js +0 -175
- package/build/src/demo/DemoPage.js.map +0 -1
- package/build/src/demo/DemoStyles.d.ts +0 -3
- package/build/src/demo/DemoStyles.d.ts.map +0 -1
- package/build/src/demo/DemoStyles.js +0 -60
- package/build/src/demo/DemoStyles.js.map +0 -1
- package/build/src/elements/contextual-menu/internals/ContextualMenu.d.ts.map +0 -1
- package/build/src/elements/contextual-menu/internals/ContextualMenu.js.map +0 -1
- package/build/test/elements/navigation/Navigation.test.d.ts +0 -3
- package/build/test/elements/navigation/Navigation.test.d.ts.map +0 -1
- package/build/test/elements/navigation/Navigation.test.js +0 -113
- package/build/test/elements/navigation/Navigation.test.js.map +0 -1
- package/commitlint.config.cjs +0 -2
- package/demo/elements/authorization/AuthPlugin.js +0 -57
- package/demo/elements/authorization/AuthProxy.js +0 -215
- package/demo/elements/authorization/api-key.html +0 -27
- package/demo/elements/authorization/api-key.ts +0 -44
- package/demo/elements/authorization/basic.html +0 -27
- package/demo/elements/authorization/basic.ts +0 -43
- package/demo/elements/authorization/bearer.html +0 -27
- package/demo/elements/authorization/bearer.ts +0 -43
- package/demo/elements/authorization/env.js +0 -8
- package/demo/elements/authorization/index.html +0 -44
- package/demo/elements/authorization/ntlm.html +0 -27
- package/demo/elements/authorization/ntlm.ts +0 -43
- package/demo/elements/authorization/oauth-authorize.html +0 -75
- package/demo/elements/authorization/oauth-authorize.ts +0 -40
- package/demo/elements/authorization/oauth-error.html +0 -18
- package/demo/elements/authorization/oauth-error.ts +0 -10
- package/demo/elements/authorization/oauth-popup.html +0 -36
- package/demo/elements/authorization/oauth2.html +0 -27
- package/demo/elements/authorization/oauth2.ts +0 -100
- package/demo/elements/authorization/oidc.html +0 -27
- package/demo/elements/authorization/oidc.ts +0 -139
- package/demo/elements/authorization/private.crt +0 -31
- package/demo/elements/authorization/private.csr +0 -28
- package/demo/elements/authorization/private.key +0 -51
- package/demo/elements/authorization/private.pem +0 -31
- package/demo/elements/authorization/redirect.html +0 -20
- package/demo/elements/authorization/ssl-commands.sh +0 -30
- package/demo/elements/authorization/ssl.conf +0 -24
- package/demo/elements/autocomplete/index.html +0 -64
- package/demo/elements/autocomplete/index.ts +0 -171
- package/demo/elements/code-editor/CodeEditorDemo.ts +0 -173
- package/demo/elements/code-editor/index.html +0 -19
- package/demo/elements/context-menu/DemoIcons.ts +0 -21
- package/demo/elements/context-menu/basic.html +0 -25
- package/demo/elements/context-menu/basic.ts +0 -119
- package/demo/elements/context-menu/custom-data.html +0 -25
- package/demo/elements/context-menu/custom-data.ts +0 -62
- package/demo/elements/context-menu/demo.css +0 -28
- package/demo/elements/context-menu/enabled-state.html +0 -25
- package/demo/elements/context-menu/enabled-state.ts +0 -73
- package/demo/elements/context-menu/icons.html +0 -25
- package/demo/elements/context-menu/icons.ts +0 -64
- package/demo/elements/context-menu/index.html +0 -43
- package/demo/elements/context-menu/nested.html +0 -25
- package/demo/elements/context-menu/nestedt.ts +0 -152
- package/demo/elements/context-menu/no-execute.html +0 -25
- package/demo/elements/context-menu/no-execute.ts +0 -134
- package/demo/elements/context-menu/radio-menu.html +0 -25
- package/demo/elements/context-menu/radio-menu.ts +0 -83
- package/demo/elements/context-menu/separators.html +0 -25
- package/demo/elements/context-menu/separators.ts +0 -172
- package/demo/elements/currency/index.html +0 -91
- package/demo/elements/currency/index.ts +0 -352
- package/demo/elements/environment/environment-editor.html +0 -20
- package/demo/elements/environment/environment-editor.ts +0 -49
- package/demo/elements/environment/index.html +0 -33
- package/demo/elements/environment/server-editor.html +0 -20
- package/demo/elements/environment/server-editor.ts +0 -67
- package/demo/elements/environment/variables-editor.html +0 -20
- package/demo/elements/environment/variables-editor.ts +0 -94
- package/demo/elements/har/har-viewer.html +0 -20
- package/demo/elements/har/har-viewer.ts +0 -76
- package/demo/elements/har/har1.har +0 -3044
- package/demo/elements/har/har2.json +0 -439
- package/demo/elements/har/index.html +0 -26
- package/demo/elements/highlight/example.md +0 -27
- package/demo/elements/highlight/index.html +0 -31
- package/demo/elements/highlight/marked-highlight.html +0 -132
- package/demo/elements/highlight/marked-highlight.ts +0 -22
- package/demo/elements/highlight/prism-highlight.html +0 -62
- package/demo/elements/highlight/prism-highlight.ts +0 -17
- package/demo/elements/http/body-editor.html +0 -17
- package/demo/elements/http/body-editor.ts +0 -115
- package/demo/elements/http/headers.html +0 -17
- package/demo/elements/http/headers.ts +0 -59
- package/demo/elements/http/http-assertions.html +0 -20
- package/demo/elements/http/http-assertions.ts +0 -89
- package/demo/elements/http/http-flows.html +0 -23
- package/demo/elements/http/http-flows.ts +0 -89
- package/demo/elements/http/index.html +0 -45
- package/demo/elements/http/request-editor.html +0 -26
- package/demo/elements/http/request-editor.ts +0 -197
- package/demo/elements/http/request-log.html +0 -16
- package/demo/elements/http/request-log.ts +0 -136
- package/demo/elements/http/url-editing.html +0 -17
- package/demo/elements/http/url-editing.ts +0 -112
- package/demo/elements/icons/index.html +0 -81
- package/demo/elements/icons/index.ts +0 -52
- package/demo/elements/index.html +0 -72
- package/demo/elements/mention-textarea/index.html +0 -19
- package/demo/elements/mention-textarea/index.ts +0 -205
- package/demo/elements/navigation/navigation-item.html +0 -49
- package/demo/elements/navigation/navigation-item.ts +0 -131
- package/demo/elements/navigation/navigation.html +0 -20
- package/demo/elements/navigation/navigation.ts +0 -45
- package/demo/elements/project/index.html +0 -29
- package/demo/elements/project/project-run-report.html +0 -20
- package/demo/elements/project/project-run-report.ts +0 -132
- package/demo/elements/project/request-editor.html +0 -23
- package/demo/elements/project/request-editor.ts +0 -232
- package/demo/elements/user/user-avatar.html +0 -17
- package/demo/elements/user/user-avatar.ts +0 -60
- package/demo/env.js +0 -4
- package/demo/index.html +0 -34
- package/demo/layout/index.html +0 -94
- package/demo/layout/index.ts +0 -190
- package/demo/md/DemoStyles.ts +0 -61
- package/demo/md/UiDemoPage.ts +0 -6
- package/demo/md/buttons/button.html +0 -121
- package/demo/md/buttons/button.ts +0 -246
- package/demo/md/buttons/group.html +0 -36
- package/demo/md/buttons/group.ts +0 -171
- package/demo/md/checkbox/index.html +0 -39
- package/demo/md/checkbox/index.ts +0 -220
- package/demo/md/chip/chip.html +0 -70
- package/demo/md/chip/chip.ts +0 -219
- package/demo/md/chip/pawel6c9a.jpg +0 -0
- package/demo/md/collapse/CustomDetail.ts +0 -89
- package/demo/md/collapse/collapse.html +0 -21
- package/demo/md/collapse/collapse.ts +0 -78
- package/demo/md/date-picker/date-picker.ts +0 -336
- package/demo/md/date-picker/index.html +0 -171
- package/demo/md/dialog/confirm-dialog.html +0 -49
- package/demo/md/dialog/confirm-dialog.ts +0 -121
- package/demo/md/dialog/dialog.html +0 -25
- package/demo/md/dialog/dialog.ts +0 -468
- package/demo/md/dropdown-list/index.html +0 -31
- package/demo/md/dropdown-list/index.ts +0 -158
- package/demo/md/icon-button/index.html +0 -122
- package/demo/md/icon-button/index.ts +0 -132
- package/demo/md/index.html +0 -73
- package/demo/md/inputs/input.html +0 -73
- package/demo/md/inputs/input.ts +0 -278
- package/demo/md/inputs/radio.html +0 -39
- package/demo/md/inputs/radio.ts +0 -156
- package/demo/md/inputs/switch.html +0 -45
- package/demo/md/inputs/switch.ts +0 -144
- package/demo/md/list/list.html +0 -65
- package/demo/md/list/list.ts +0 -204
- package/demo/md/listbox/listbox.html +0 -31
- package/demo/md/listbox/listbox.ts +0 -27
- package/demo/md/menu/index.html +0 -19
- package/demo/md/menu/index.ts +0 -514
- package/demo/md/notification/snack.html +0 -21
- package/demo/md/notification/snack.ts +0 -70
- package/demo/md/progress/progress.html +0 -46
- package/demo/md/progress/progress.ts +0 -161
- package/demo/md/segmented-button/index.html +0 -21
- package/demo/md/segmented-button/index.ts +0 -55
- package/demo/md/select/index.html +0 -16
- package/demo/md/select/index.ts +0 -217
- package/demo/md/tabs/tabs.html +0 -40
- package/demo/md/tabs/tabs.ts +0 -214
- package/demo/oauth-popup.html +0 -36
- package/demo/page.css +0 -8
- package/demo/resources/calendar-month.png +0 -0
- package/demo/resources/favorite.png +0 -0
- package/demo/resources/fingerprint.png +0 -0
- package/demo/resources/home-work.png +0 -0
- package/demo/resources/mood.png +0 -0
- package/demo/resources/print.png +0 -0
- package/demo/resources/stars.png +0 -0
- package/demo/resources/theaters.png +0 -0
- package/demo/tsconfig.json +0 -4
- package/eslint.config.js +0 -97
- package/scripts/copy-assets.js +0 -21
- package/scripts/release.js +0 -66
- package/src/demo/DemoPage.ts +0 -169
- package/src/demo/DemoStyles.ts +0 -60
- package/test/README.md +0 -375
- package/test/contextual-menu/ContextMenu.test.ts +0 -760
- package/test/contextual-menu/ContextMenuElement.test.ts +0 -569
- package/test/core/activity.spec.ts +0 -413
- package/test/core/activity_manager.spec.ts +0 -544
- package/test/core/application.spec.ts +0 -218
- package/test/core/fragment.spec.ts +0 -565
- package/test/core/fragment_manager.spec.ts +0 -404
- package/test/core/live_data.spec.ts +0 -558
- package/test/core/renderer.spec.ts +0 -113
- package/test/dom-assertions.test.ts +0 -182
- package/test/elements/MonacoSetup.ts +0 -65
- package/test/elements/authorization/basic-method.test.ts +0 -177
- package/test/elements/authorization/bearer-method.test.ts +0 -143
- package/test/elements/authorization/ntlm-method.test.ts +0 -219
- package/test/elements/authorization/oauth2-client-credentials-method.test.ts +0 -334
- package/test/elements/authorization/oauth2-code-method.test.ts +0 -320
- package/test/elements/authorization/oauth2-custom-grant-method.test.ts +0 -255
- package/test/elements/authorization/oauth2-device-code-method.test.ts +0 -371
- package/test/elements/authorization/oauth2-implicit-method.test.ts +0 -407
- package/test/elements/authorization/oauth2-jwt-method.test.ts +0 -217
- package/test/elements/authorization/oauth2-password-method.test.ts +0 -275
- package/test/elements/authorization/openid-method.test.ts +0 -591
- package/test/elements/autocomplete/autocomplete-input.spec.ts +0 -646
- package/test/elements/code-editor/code-editor.accessibility.test.ts +0 -298
- package/test/elements/code-editor/code-editor.test.ts +0 -574
- package/test/elements/currency/CurrencyPicker.accessibility.test.ts +0 -328
- package/test/elements/currency/CurrencyPicker.core.test.ts +0 -318
- package/test/elements/currency/CurrencyPicker.integration.test.ts +0 -482
- package/test/elements/currency/CurrencyPicker.test.ts +0 -486
- package/test/elements/data-table/DataTable.browser.test.ts +0 -649
- package/test/elements/har/HarUtils.test.ts +0 -45
- package/test/elements/har/HarViewerElement.test.ts +0 -687
- package/test/elements/har/test-data/har1.har +0 -3044
- package/test/elements/highlight/MarkedHighlightElement.test.ts +0 -452
- package/test/elements/highlight/PrismHighlightElement.test.ts +0 -79
- package/test/elements/highlight/PrismHighlighter.test.ts +0 -94
- package/test/elements/highlight/remoteSanitization.md +0 -1
- package/test/elements/highlight/test.md +0 -3
- package/test/elements/highlight/test1.md +0 -3
- package/test/elements/highlight/test2.md +0 -1
- package/test/elements/http/BodyFormdataEditorElement.test.ts +0 -482
- package/test/elements/http/BodyMultipartEditorElement.test.ts +0 -658
- package/test/elements/http/BodyRawEditorElement.test.ts +0 -90
- package/test/elements/http/CertificateAdd.test.ts +0 -457
- package/test/elements/http/HttpAssertions.test.ts +0 -994
- package/test/elements/http/HttpFlows.test.ts +0 -502
- package/test/elements/http/UrlEncodeUtils.test.ts +0 -202
- package/test/elements/layout/SplitItem.test.ts +0 -440
- package/test/elements/layout/SplitLayoutManager.test.ts +0 -1501
- package/test/elements/layout/SplitPanel.test.ts +0 -1109
- package/test/elements/mention-textarea/MentionTextArea.basic.test.ts +0 -114
- package/test/elements/mention-textarea/MentionTextArea.test.ts +0 -613
- package/test/elements/navigation/Navigation.test.ts +0 -120
- package/test/env.ts +0 -15
- package/test/events/EventTypes.test.ts +0 -363
- package/test/events/EventsTestHelpers.ts +0 -16
- package/test/helpers/TestUtils.ts +0 -243
- package/test/helpers/UiMock.ts +0 -185
- package/test/lib/Dom.test.ts +0 -231
- package/test/md/button/UiButton.test.ts +0 -347
- package/test/md/button/UiIconButton.test.ts +0 -155
- package/test/md/chip/UiChip.test.ts +0 -219
- package/test/md/collapse/UiCollapse.test.ts +0 -250
- package/test/md/collapse/flex-layout.test.ts +0 -105
- package/test/md/date-time/DateTime.test.ts +0 -348
- package/test/md/dialog/UiConfirmDialog.test.ts +0 -131
- package/test/md/dialog/UiDialog.test.ts +0 -759
- package/test/md/menu/Menu.test.ts +0 -855
- package/test/md/menu/MenuIntegration.test.ts +0 -426
- package/test/md/menu/MenuItem.test.ts +0 -652
- package/test/md/menu/SubMenu.test.ts +0 -410
- package/test/md/progress/UiCircularProgressElement.test.ts +0 -481
- package/test/md/progress/UiProgressElement.test.ts +0 -117
- package/test/md/progress/UiRangeElement.test.ts +0 -156
- package/test/md/select/Select.test.ts +0 -925
- package/test/plugins/takeScreenshotPlugin.js +0 -35
- package/test/setup.test.ts +0 -217
- package/test/setup.ts +0 -117
- package/test/tsconfig.json +0 -7
- package/web-dev-server.config.js +0 -21
- package/web-test-runner.config.js +0 -90
|
@@ -1,544 +0,0 @@
|
|
|
1
|
-
import { assert } from '@esm-bundle/chai'
|
|
2
|
-
import sinon from 'sinon'
|
|
3
|
-
import { fixture, html } from '@open-wc/testing'
|
|
4
|
-
import { Activity } from '../../src/core/Activity.js'
|
|
5
|
-
import { Application } from '../../src/core/Application.js'
|
|
6
|
-
import {
|
|
7
|
-
ActivityManager,
|
|
8
|
-
ActivityLifecycle,
|
|
9
|
-
IntentFlags,
|
|
10
|
-
IntentResult,
|
|
11
|
-
type Intent,
|
|
12
|
-
} from '../../src/core/ActivityManager.js'
|
|
13
|
-
|
|
14
|
-
class TestActivity extends Activity {
|
|
15
|
-
static override action = 'test-activity'
|
|
16
|
-
override onCreate = sinon.stub().resolves()
|
|
17
|
-
override onStart = sinon.stub().resolves()
|
|
18
|
-
override onResume = sinon.stub().resolves()
|
|
19
|
-
override onPause = sinon.stub().resolves()
|
|
20
|
-
override onStop = sinon.stub().resolves()
|
|
21
|
-
override onRestart = sinon.stub().resolves()
|
|
22
|
-
override onDestroy = sinon.stub().resolves()
|
|
23
|
-
override onNewIntent = sinon.stub().resolves()
|
|
24
|
-
override onActivityResult = sinon.stub().resolves()
|
|
25
|
-
|
|
26
|
-
override setResult = sinon.spy(super.setResult) // Spy on the actual implementation
|
|
27
|
-
override getResult = sinon.spy(super.getResult)
|
|
28
|
-
override hasRequestCode = sinon.spy(super.hasRequestCode)
|
|
29
|
-
|
|
30
|
-
// Helper to reset stubs for each test
|
|
31
|
-
resetStubs() {
|
|
32
|
-
this.onCreate.resetHistory()
|
|
33
|
-
this.onStart.resetHistory()
|
|
34
|
-
this.onResume.resetHistory()
|
|
35
|
-
this.onPause.resetHistory()
|
|
36
|
-
this.onStop.resetHistory()
|
|
37
|
-
this.onRestart.resetHistory()
|
|
38
|
-
this.onDestroy.resetHistory()
|
|
39
|
-
this.onNewIntent.resetHistory()
|
|
40
|
-
this.onActivityResult.resetHistory()
|
|
41
|
-
this.setResult.resetHistory()
|
|
42
|
-
this.getResult.resetHistory()
|
|
43
|
-
this.hasRequestCode.resetHistory()
|
|
44
|
-
this.lifecycle = ActivityLifecycle.Initialized
|
|
45
|
-
this.pendingRequestCodes.length = 0
|
|
46
|
-
this.exitCode = IntentResult.RESULT_CANCELED
|
|
47
|
-
this.resultData = undefined
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
class TestActivity2 extends TestActivity {
|
|
52
|
-
static override action = 'test-activity-2'
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
class TestApplication extends Application {
|
|
56
|
-
requestUpdateSpy = sinon.spy(this, 'requestUpdate')
|
|
57
|
-
|
|
58
|
-
override async onStart(): Promise<void> {}
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
async function basicFixture(): Promise<HTMLElement> {
|
|
62
|
-
return fixture(html`<div id="app"></div>`)
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
describe('ActivityManager', () => {
|
|
66
|
-
let app: TestApplication
|
|
67
|
-
let manager: ActivityManager
|
|
68
|
-
// let navigateScreenStub: sinon.SinonStub
|
|
69
|
-
|
|
70
|
-
beforeEach(async () => {
|
|
71
|
-
const renderRoot = await basicFixture()
|
|
72
|
-
app = new TestApplication(renderRoot)
|
|
73
|
-
manager = app.manager
|
|
74
|
-
manager.registerActivity(TestActivity.action, TestActivity)
|
|
75
|
-
manager.registerActivity(TestActivity2.action, TestActivity2)
|
|
76
|
-
// navigateScreenStub = sinon.stub(ApplicationRoute, 'navigateScreen')
|
|
77
|
-
// Clear any classes added by previous tests
|
|
78
|
-
if (document.documentElement) {
|
|
79
|
-
document.documentElement.className = ''
|
|
80
|
-
}
|
|
81
|
-
})
|
|
82
|
-
|
|
83
|
-
afterEach(() => {
|
|
84
|
-
sinon.restore()
|
|
85
|
-
})
|
|
86
|
-
|
|
87
|
-
describe('registerActivity()', () => {
|
|
88
|
-
it('registers an activity class', () => {
|
|
89
|
-
const newAction = 'new-test-activity'
|
|
90
|
-
class NewTestActivity extends Activity {
|
|
91
|
-
static override action = newAction
|
|
92
|
-
}
|
|
93
|
-
manager.registerActivity(newAction, NewTestActivity)
|
|
94
|
-
assert.isTrue(manager['activityClasses'].has(newAction))
|
|
95
|
-
assert.strictEqual(manager['activityClasses'].get(newAction), NewTestActivity)
|
|
96
|
-
})
|
|
97
|
-
|
|
98
|
-
it('warns if an activity with the same action is already registered', () => {
|
|
99
|
-
const consoleWarnSpy = sinon.stub(console, 'warn')
|
|
100
|
-
manager.registerActivity(TestActivity.action, TestActivity) // Registering again
|
|
101
|
-
consoleWarnSpy.restore()
|
|
102
|
-
assert.isTrue(consoleWarnSpy.calledOnce)
|
|
103
|
-
assert.include(
|
|
104
|
-
consoleWarnSpy.firstCall.args[0],
|
|
105
|
-
`Activity with action "${TestActivity.action}" already registered.`
|
|
106
|
-
)
|
|
107
|
-
})
|
|
108
|
-
})
|
|
109
|
-
|
|
110
|
-
describe('createActivity()', () => {
|
|
111
|
-
it('creates an activity and adds it to the stack without starting it', async () => {
|
|
112
|
-
const intent: Intent = { action: TestActivity.action }
|
|
113
|
-
await manager.createActivity(intent)
|
|
114
|
-
assert.equal(manager['activityStack'].length, 1)
|
|
115
|
-
const entry = manager['activityStack'][0]
|
|
116
|
-
assert.instanceOf(entry.activity, TestActivity)
|
|
117
|
-
assert.equal(entry.activity.lifecycle, ActivityLifecycle.Initialized)
|
|
118
|
-
assert.strictEqual(entry.intent, intent)
|
|
119
|
-
assert.isUndefined(manager.getCurrentActivity())
|
|
120
|
-
})
|
|
121
|
-
|
|
122
|
-
it('throws if activity class is not registered', async () => {
|
|
123
|
-
const intent: Intent = { action: 'unknown-action' }
|
|
124
|
-
try {
|
|
125
|
-
await manager.createActivity(intent)
|
|
126
|
-
assert.fail('Should have thrown an error')
|
|
127
|
-
} catch (e) {
|
|
128
|
-
assert.equal((e as Error).message, 'No activity class registered for action: unknown-action')
|
|
129
|
-
}
|
|
130
|
-
})
|
|
131
|
-
})
|
|
132
|
-
|
|
133
|
-
describe('startActivity()', () => {
|
|
134
|
-
it('starts a new activity, no current activity', async () => {
|
|
135
|
-
const intent: Intent = { action: TestActivity.action }
|
|
136
|
-
await manager.startActivity(intent)
|
|
137
|
-
|
|
138
|
-
assert.equal(manager['activityStack'].length, 1)
|
|
139
|
-
const entry = manager['activityStack'][0]
|
|
140
|
-
assert.instanceOf(entry.activity, TestActivity)
|
|
141
|
-
assert.strictEqual(manager.getCurrentActivity(), entry.activity)
|
|
142
|
-
assert.isTrue((entry.activity as TestActivity).onCreate.calledOnceWith(intent))
|
|
143
|
-
assert.isTrue((entry.activity as TestActivity).onStart.calledOnce)
|
|
144
|
-
assert.isTrue((entry.activity as TestActivity).onResume.calledOnce)
|
|
145
|
-
assert.equal(entry.activity.lifecycle, ActivityLifecycle.Resumed)
|
|
146
|
-
// assert.isFalse(navigateScreenStub.called) // No URI in intent
|
|
147
|
-
})
|
|
148
|
-
|
|
149
|
-
it('starts a new activity with URI in intent', async () => {
|
|
150
|
-
const uri = '/test/start'
|
|
151
|
-
const intent: Intent = { action: TestActivity.action, data: { uri } }
|
|
152
|
-
await manager.startActivity(intent)
|
|
153
|
-
// assert.isTrue(navigateScreenStub.calledOnceWith(uri))
|
|
154
|
-
})
|
|
155
|
-
|
|
156
|
-
it('starts a new activity, with a current activity', async () => {
|
|
157
|
-
const intent1: Intent = { action: TestActivity.action }
|
|
158
|
-
await manager.startActivity(intent1)
|
|
159
|
-
const activity1 = manager.getCurrentActivity() as TestActivity
|
|
160
|
-
|
|
161
|
-
const intent2: Intent = { action: TestActivity2.action }
|
|
162
|
-
await manager.startActivity(intent2)
|
|
163
|
-
const activity2 = manager.getCurrentActivity() as TestActivity
|
|
164
|
-
assert.isTrue(activity1.onPause.calledOnce, 'activity1 onPause should be called once')
|
|
165
|
-
assert.equal(activity1.lifecycle, ActivityLifecycle.Paused, 'activity1 should be paused')
|
|
166
|
-
|
|
167
|
-
assert.isTrue(activity2.onCreate.calledOnceWith(intent2), 'activity2 onCreate should be called with intent')
|
|
168
|
-
assert.isTrue(activity2.onStart.calledOnce, 'activity2 onStart should be called once')
|
|
169
|
-
assert.isTrue(activity2.onResume.calledOnce, 'activity2 onResume should be called once')
|
|
170
|
-
assert.equal(activity2.lifecycle, ActivityLifecycle.Resumed, 'activity2 should be resumed')
|
|
171
|
-
assert.equal(manager['activityStack'].length, 2, 'activity stack should have 2 activities')
|
|
172
|
-
})
|
|
173
|
-
|
|
174
|
-
it('brings an existing activity from stack to front and calls onNewIntent', async () => {
|
|
175
|
-
const intent1: Intent = { action: TestActivity.action, data: { initial: true } }
|
|
176
|
-
await manager.startActivity(intent1)
|
|
177
|
-
const activity1 = manager.getCurrentActivity() as TestActivity
|
|
178
|
-
activity1.resetStubs()
|
|
179
|
-
|
|
180
|
-
const intent2: Intent = { action: TestActivity2.action }
|
|
181
|
-
await manager.startActivity(intent2)
|
|
182
|
-
const activity2 = manager.getCurrentActivity() as TestActivity
|
|
183
|
-
|
|
184
|
-
// activity1 is now paused, activity2 is resumed
|
|
185
|
-
assert.equal(activity1.lifecycle, ActivityLifecycle.Paused, 'activity1 should be paused')
|
|
186
|
-
assert.equal(activity2.lifecycle, ActivityLifecycle.Resumed, 'activity2 should be resumed')
|
|
187
|
-
|
|
188
|
-
const newIntentForActivity1: Intent = { action: TestActivity.action, data: { updated: true } }
|
|
189
|
-
await manager.startActivity(newIntentForActivity1)
|
|
190
|
-
|
|
191
|
-
assert.strictEqual(manager.getCurrentActivity(), activity1)
|
|
192
|
-
assert.isTrue(activity1.onNewIntent.calledOnceWith(newIntentForActivity1), 'activity1 called with new intent')
|
|
193
|
-
assert.isTrue(activity1.onResume.calledOnce, 'activity1 onResume called once') // Should be resumed
|
|
194
|
-
assert.equal(activity1.lifecycle, ActivityLifecycle.Resumed, 'activity1 should be resumed')
|
|
195
|
-
|
|
196
|
-
assert.isTrue(activity2.onPause.calledOnce, 'activity2 paused once') // activity2 should be paused
|
|
197
|
-
assert.equal(activity2.lifecycle, ActivityLifecycle.Paused, 'activity2 should be paused')
|
|
198
|
-
|
|
199
|
-
assert.equal(manager['activityStack'].length, 2, 'activityStack is the same') // Stack size remains the same
|
|
200
|
-
assert.strictEqual(manager['activityStack'][1].activity, activity1) // activity1 is now at the top
|
|
201
|
-
assert.deepEqual(manager['activityStack'][1].intent, newIntentForActivity1)
|
|
202
|
-
})
|
|
203
|
-
|
|
204
|
-
it('starts a modal activity', async () => {
|
|
205
|
-
const intent1: Intent = { action: TestActivity.action }
|
|
206
|
-
await manager.startActivity(intent1)
|
|
207
|
-
const activity1 = manager.getCurrentActivity() as TestActivity
|
|
208
|
-
|
|
209
|
-
const modalIntent: Intent = { action: TestActivity2.action, flags: IntentFlags.Modal }
|
|
210
|
-
await manager.startActivity(modalIntent)
|
|
211
|
-
|
|
212
|
-
const modalActivity = manager['modalActivityStack'][0].activity as TestActivity2
|
|
213
|
-
assert.equal(manager['modalActivityStack'].length, 1)
|
|
214
|
-
assert.strictEqual(manager['modalActivityStack'][0].activity, modalActivity)
|
|
215
|
-
|
|
216
|
-
assert.isTrue(activity1.onPause.calledOnce)
|
|
217
|
-
assert.equal(activity1.lifecycle, ActivityLifecycle.Paused)
|
|
218
|
-
// For modal, currentActivity in manager should still be the underlying one
|
|
219
|
-
assert.strictEqual(manager.getCurrentActivity(), activity1)
|
|
220
|
-
|
|
221
|
-
assert.isTrue(modalActivity.onCreate.calledOnceWith(modalIntent))
|
|
222
|
-
assert.isTrue(modalActivity.onStart.calledOnce)
|
|
223
|
-
assert.isTrue(modalActivity.onResume.calledOnce)
|
|
224
|
-
assert.equal(modalActivity.lifecycle, ActivityLifecycle.Resumed)
|
|
225
|
-
})
|
|
226
|
-
|
|
227
|
-
it('throws if activity class is not registered', async () => {
|
|
228
|
-
const intent: Intent = { action: 'unknown-action' }
|
|
229
|
-
try {
|
|
230
|
-
await manager.startActivity(intent)
|
|
231
|
-
assert.fail('Should have thrown an error')
|
|
232
|
-
} catch (e) {
|
|
233
|
-
assert.equal((e as Error).message, 'No activity class registered for action: unknown-action')
|
|
234
|
-
}
|
|
235
|
-
})
|
|
236
|
-
})
|
|
237
|
-
|
|
238
|
-
describe('startActivityForResult()', () => {
|
|
239
|
-
it('starts activity with ForResult flag and requestCode', async () => {
|
|
240
|
-
const startActivitySpy = sinon.spy(manager, 'startActivity')
|
|
241
|
-
const intent: Intent = { action: TestActivity.action, data: { test: 1 } }
|
|
242
|
-
const requestCode = 123
|
|
243
|
-
|
|
244
|
-
await manager.startActivityForResult(intent, requestCode)
|
|
245
|
-
|
|
246
|
-
assert.isTrue(startActivitySpy.calledOnce, 'startActivity should be called once')
|
|
247
|
-
const calledIntent = startActivitySpy.firstCall.args[0]
|
|
248
|
-
assert.equal(calledIntent.action, TestActivity.action, 'Intent action should match')
|
|
249
|
-
assert.deepEqual(calledIntent.data, { test: 1 }, 'Intent data should match')
|
|
250
|
-
assert.equal(calledIntent.requestCode, requestCode, 'Request code should match')
|
|
251
|
-
assert.isNumber(calledIntent.flags, 'Flags should be defined')
|
|
252
|
-
assert.isTrue(!!(calledIntent.flags! & IntentFlags.ForResult), 'ForResult flag should be set')
|
|
253
|
-
})
|
|
254
|
-
|
|
255
|
-
it('clones intent data by default', async () => {
|
|
256
|
-
const startActivitySpy = sinon.spy(manager, 'startActivity')
|
|
257
|
-
const originalData = { test: 1 }
|
|
258
|
-
const intent: Intent = { action: TestActivity.action, data: originalData }
|
|
259
|
-
const requestCode = 123
|
|
260
|
-
|
|
261
|
-
await manager.startActivityForResult(intent, requestCode)
|
|
262
|
-
const calledIntent = startActivitySpy.firstCall.args[0]
|
|
263
|
-
assert.notStrictEqual(calledIntent.data, originalData)
|
|
264
|
-
assert.deepEqual(calledIntent.data, originalData)
|
|
265
|
-
intent.action = 'other'
|
|
266
|
-
;(intent.data as { test: number }).test = 2
|
|
267
|
-
assert.equal(calledIntent.action, TestActivity.action, 'Intent action should be cloned, not by reference')
|
|
268
|
-
assert.deepEqual(calledIntent.data, { test: 1 }, 'Intent data should be cloned, not by reference')
|
|
269
|
-
})
|
|
270
|
-
|
|
271
|
-
it('passes intent data by reference if ByReference flag is set', async () => {
|
|
272
|
-
const startActivitySpy = sinon.spy(manager, 'startActivity')
|
|
273
|
-
const originalData = { test: 1 }
|
|
274
|
-
const intent: Intent = { action: TestActivity.action, data: originalData, flags: IntentFlags.ByReference }
|
|
275
|
-
const requestCode = 123
|
|
276
|
-
await manager.startActivityForResult(intent, requestCode)
|
|
277
|
-
const calledIntent = startActivitySpy.firstCall.args[0]
|
|
278
|
-
assert.strictEqual(calledIntent.data, originalData, 'data is passed by reference')
|
|
279
|
-
assert.isTrue(!!(calledIntent.flags && calledIntent.flags & IntentFlags.ByReference), 'has the ByReference flag')
|
|
280
|
-
assert.isTrue(!!(calledIntent.flags && calledIntent.flags & IntentFlags.ForResult), 'has the ForResult flag')
|
|
281
|
-
|
|
282
|
-
intent.action = 'other'
|
|
283
|
-
originalData.test = 2
|
|
284
|
-
assert.equal(calledIntent.action, TestActivity.action, 'Intent action should be cloned, not by reference')
|
|
285
|
-
assert.deepEqual(calledIntent.data, { test: 2 }, 'Intent data should be passed by reference')
|
|
286
|
-
})
|
|
287
|
-
})
|
|
288
|
-
|
|
289
|
-
describe('finishActivity()', () => {
|
|
290
|
-
it('finishes the current activity and resumes the previous one', async () => {
|
|
291
|
-
const intent1: Intent = { action: TestActivity.action }
|
|
292
|
-
await manager.startActivity(intent1)
|
|
293
|
-
const activity1 = manager.getCurrentActivity() as TestActivity
|
|
294
|
-
|
|
295
|
-
const intent2: Intent = { action: TestActivity2.action }
|
|
296
|
-
await manager.startActivity(intent2)
|
|
297
|
-
const activity2 = manager.getCurrentActivity() as TestActivity2
|
|
298
|
-
activity1.resetStubs() // activity1 was paused
|
|
299
|
-
await manager.finishActivity(activity2)
|
|
300
|
-
|
|
301
|
-
assert.isTrue(activity2.onPause.calledOnce, 'activity2 onPause should be called once')
|
|
302
|
-
assert.isTrue(activity2.onStop.calledOnce, 'activity2 onStop should be called once')
|
|
303
|
-
assert.isTrue(activity2.onDestroy.calledOnce, 'activity2 onDestroy should be called once')
|
|
304
|
-
assert.equal(activity2.lifecycle, ActivityLifecycle.Destroyed, 'activity2 should be destroyed')
|
|
305
|
-
|
|
306
|
-
assert.strictEqual(manager.getCurrentActivity(), activity1)
|
|
307
|
-
assert.isTrue(activity1.onResume.calledOnce, 'activity1 onResume should be called once')
|
|
308
|
-
assert.equal(activity1.lifecycle, ActivityLifecycle.Resumed, 'activity1 should be resumed')
|
|
309
|
-
assert.equal(manager['activityStack'].length, 1, 'activity stack should have 1 activity')
|
|
310
|
-
assert.isTrue(app.requestUpdateSpy.called, 'Application should request update after finishing activity')
|
|
311
|
-
})
|
|
312
|
-
|
|
313
|
-
it('finishes a modal activity and resumes the underlying activity', async () => {
|
|
314
|
-
const intent1: Intent = { action: TestActivity.action }
|
|
315
|
-
await manager.startActivity(intent1)
|
|
316
|
-
const activity1 = manager.getCurrentActivity() as TestActivity
|
|
317
|
-
|
|
318
|
-
const modalIntent: Intent = { action: TestActivity2.action, flags: IntentFlags.Modal }
|
|
319
|
-
await manager.startActivity(modalIntent)
|
|
320
|
-
const modalActivity = manager['modalActivityStack'][0].activity as TestActivity2
|
|
321
|
-
activity1.resetStubs() // activity1 was paused
|
|
322
|
-
|
|
323
|
-
await manager.finishActivity(modalActivity)
|
|
324
|
-
|
|
325
|
-
assert.isTrue(modalActivity.onPause.calledOnce)
|
|
326
|
-
assert.isTrue(modalActivity.onStop.calledOnce)
|
|
327
|
-
assert.isTrue(modalActivity.onDestroy.calledOnce)
|
|
328
|
-
assert.equal(modalActivity.lifecycle, ActivityLifecycle.Destroyed)
|
|
329
|
-
assert.equal(manager['modalActivityStack'].length, 0)
|
|
330
|
-
|
|
331
|
-
assert.strictEqual(manager.getCurrentActivity(), activity1) // Current activity should be the underlying one
|
|
332
|
-
assert.isTrue(activity1.onResume.calledOnce)
|
|
333
|
-
assert.equal(activity1.lifecycle, ActivityLifecycle.Resumed)
|
|
334
|
-
assert.equal(manager['activityStack'].length, 1)
|
|
335
|
-
})
|
|
336
|
-
|
|
337
|
-
it('manages activity result if activity was started for result', async () => {
|
|
338
|
-
const intent1: Intent = { action: TestActivity.action }
|
|
339
|
-
await manager.startActivity(intent1)
|
|
340
|
-
const activity1 = manager.getCurrentActivity() as TestActivity
|
|
341
|
-
const requestCode = await activity1.startActivityForResult({ action: TestActivity2.action })
|
|
342
|
-
// activity1 starts activity2
|
|
343
|
-
|
|
344
|
-
// manager.startActivityForResult calls manager.startActivity, which sets currentActivity
|
|
345
|
-
// So, activity2 is now the "current" in terms of lifecycle, but activity1 is the one expecting a result.
|
|
346
|
-
const activity2 = manager['activityStack'].find((e) => e.action === TestActivity2.action)
|
|
347
|
-
?.activity as TestActivity2
|
|
348
|
-
assert.ok(activity2, 'Activity2 should be on stack')
|
|
349
|
-
|
|
350
|
-
const resultData = { success: true }
|
|
351
|
-
activity2.setResult(IntentResult.RESULT_OK, resultData)
|
|
352
|
-
|
|
353
|
-
await manager.finishActivity(activity2)
|
|
354
|
-
|
|
355
|
-
assert.isTrue(activity1.onActivityResult.calledOnce)
|
|
356
|
-
const [calledRequestCode, calledResultCode, calledIntent] = activity1.onActivityResult.firstCall.args
|
|
357
|
-
assert.equal(calledRequestCode, requestCode, 'has the request code from activity1')
|
|
358
|
-
assert.equal(calledResultCode, IntentResult.RESULT_OK, 'has the OK result code')
|
|
359
|
-
assert.deepEqual(calledIntent.data, resultData, 'has the result data from activity2')
|
|
360
|
-
assert.equal(calledIntent.action, TestActivity2.action, 'has the action of activity2')
|
|
361
|
-
})
|
|
362
|
-
|
|
363
|
-
it('handles finishing an activity that was only created (not fully started)', async () => {
|
|
364
|
-
const activity = new TestActivity(app)
|
|
365
|
-
activity.lifecycle = ActivityLifecycle.Created // Manually set for test
|
|
366
|
-
|
|
367
|
-
await manager.finishActivity(activity)
|
|
368
|
-
|
|
369
|
-
assert.isTrue(activity.onStop.calledOnce, 'onStop should be called for created activity')
|
|
370
|
-
assert.isTrue(activity.onDestroy.calledOnce, 'onDestroy should be called')
|
|
371
|
-
assert.equal(activity.lifecycle, ActivityLifecycle.Destroyed)
|
|
372
|
-
assert.isUndefined(manager.getCurrentActivity()) // Assuming no other activities
|
|
373
|
-
})
|
|
374
|
-
|
|
375
|
-
it('finishes the last activity on the stack', async () => {
|
|
376
|
-
const intent1: Intent = { action: TestActivity.action }
|
|
377
|
-
await manager.startActivity(intent1)
|
|
378
|
-
const activity1 = manager.getCurrentActivity() as TestActivity
|
|
379
|
-
|
|
380
|
-
await manager.finishActivity(activity1)
|
|
381
|
-
|
|
382
|
-
assert.isTrue(activity1.onDestroy.calledOnce)
|
|
383
|
-
assert.equal(activity1.lifecycle, ActivityLifecycle.Destroyed)
|
|
384
|
-
assert.isUndefined(manager.getCurrentActivity())
|
|
385
|
-
assert.equal(manager['activityStack'].length, 0)
|
|
386
|
-
})
|
|
387
|
-
})
|
|
388
|
-
|
|
389
|
-
describe('getTopActivity()', () => {
|
|
390
|
-
it('returns undefined if no activities are resumed', () => {
|
|
391
|
-
assert.isUndefined(manager.getTopActivity())
|
|
392
|
-
})
|
|
393
|
-
|
|
394
|
-
it('returns the top resumed regular activity', async () => {
|
|
395
|
-
await manager.startActivity({ action: TestActivity.action })
|
|
396
|
-
const activity1 = manager['activityStack'][0].activity
|
|
397
|
-
activity1.lifecycle = ActivityLifecycle.Resumed // Ensure it's resumed
|
|
398
|
-
|
|
399
|
-
await manager.startActivity({ action: TestActivity2.action })
|
|
400
|
-
const activity2 = manager['activityStack'][1].activity
|
|
401
|
-
activity2.lifecycle = ActivityLifecycle.Resumed // Ensure it's resumed
|
|
402
|
-
|
|
403
|
-
assert.strictEqual(manager.getTopActivity(), activity2)
|
|
404
|
-
})
|
|
405
|
-
|
|
406
|
-
it('returns the top resumed modal activity if present', async () => {
|
|
407
|
-
await manager.startActivity({ action: TestActivity.action }) // Regular activity
|
|
408
|
-
const regularActivity = manager['activityStack'][0].activity
|
|
409
|
-
regularActivity.lifecycle = ActivityLifecycle.Resumed
|
|
410
|
-
|
|
411
|
-
await manager.startActivity({ action: TestActivity2.action, flags: IntentFlags.Modal })
|
|
412
|
-
const modalActivity = manager['modalActivityStack'][0].activity
|
|
413
|
-
modalActivity.lifecycle = ActivityLifecycle.Resumed // Ensure it's resumed
|
|
414
|
-
|
|
415
|
-
assert.strictEqual(manager.getTopActivity(), modalActivity)
|
|
416
|
-
})
|
|
417
|
-
|
|
418
|
-
it('returns regular activity if modal is not resumed', async () => {
|
|
419
|
-
await manager.startActivity({ action: TestActivity.action })
|
|
420
|
-
const regularActivity = manager['activityStack'][0].activity
|
|
421
|
-
|
|
422
|
-
await manager.startActivity({ action: TestActivity2.action, flags: IntentFlags.Modal })
|
|
423
|
-
const modalActivity = manager['modalActivityStack'][0].activity
|
|
424
|
-
modalActivity.lifecycle = ActivityLifecycle.Paused // Not resumed
|
|
425
|
-
regularActivity.lifecycle = ActivityLifecycle.Resumed
|
|
426
|
-
assert.strictEqual(manager.getTopActivity(), regularActivity)
|
|
427
|
-
})
|
|
428
|
-
})
|
|
429
|
-
|
|
430
|
-
describe('getCurrentActivity()', () => {
|
|
431
|
-
it('returns undefined initially', () => {
|
|
432
|
-
assert.isUndefined(manager.getCurrentActivity())
|
|
433
|
-
})
|
|
434
|
-
|
|
435
|
-
it('returns the current activity after startActivity', async () => {
|
|
436
|
-
const intent: Intent = { action: TestActivity.action }
|
|
437
|
-
await manager.startActivity(intent)
|
|
438
|
-
assert.instanceOf(manager.getCurrentActivity(), TestActivity)
|
|
439
|
-
})
|
|
440
|
-
})
|
|
441
|
-
|
|
442
|
-
describe('setupStyles()', () => {
|
|
443
|
-
it('adds activity class name and action to documentElement classList', async () => {
|
|
444
|
-
const intent: Intent = { action: TestActivity.action }
|
|
445
|
-
await manager.startActivity(intent) // This calls setupStyles internally
|
|
446
|
-
const activity = manager.getCurrentActivity()!
|
|
447
|
-
const ctor = activity.constructor as typeof Activity
|
|
448
|
-
|
|
449
|
-
assert.isTrue(document.documentElement.classList.contains(ctor.name.toLowerCase()))
|
|
450
|
-
assert.isTrue(document.documentElement.classList.contains(ctor.action!.replace(/\//g, '-')))
|
|
451
|
-
})
|
|
452
|
-
|
|
453
|
-
it('removes old activity classes and adds new ones on activity change', async () => {
|
|
454
|
-
const intent1: Intent = { action: TestActivity.action }
|
|
455
|
-
await manager.startActivity(intent1)
|
|
456
|
-
const activity1 = manager.getCurrentActivity()!
|
|
457
|
-
const ctor1 = activity1.constructor as typeof Activity
|
|
458
|
-
|
|
459
|
-
const intent2: Intent = { action: TestActivity2.action }
|
|
460
|
-
await manager.startActivity(intent2)
|
|
461
|
-
const activity2 = manager.getCurrentActivity()!
|
|
462
|
-
const ctor2 = activity2.constructor as typeof Activity
|
|
463
|
-
|
|
464
|
-
assert.isFalse(document.documentElement.classList.contains(ctor1.name.toLowerCase()))
|
|
465
|
-
assert.isFalse(document.documentElement.classList.contains(ctor1.action!.replace(/\//g, '-')))
|
|
466
|
-
assert.isTrue(document.documentElement.classList.contains(ctor2.name.toLowerCase()))
|
|
467
|
-
assert.isTrue(document.documentElement.classList.contains(ctor2.action!.replace(/\//g, '-')))
|
|
468
|
-
})
|
|
469
|
-
|
|
470
|
-
it('does nothing if activity is the same as oldActivity', () => {
|
|
471
|
-
const activity = new TestActivity(app)
|
|
472
|
-
document.documentElement.classList.add('initial-class')
|
|
473
|
-
manager.setupStyles(activity, activity)
|
|
474
|
-
assert.isTrue(document.documentElement.classList.contains('initial-class'))
|
|
475
|
-
assert.equal(document.documentElement.classList.length, 1) // No classes added or removed
|
|
476
|
-
})
|
|
477
|
-
|
|
478
|
-
it('clears styles if old activity is provided and new one is not', () => {
|
|
479
|
-
const oldActivity = new TestActivity(app)
|
|
480
|
-
const ctorOld = oldActivity.constructor as typeof Activity
|
|
481
|
-
document.documentElement.classList.add(ctorOld.name.toLowerCase())
|
|
482
|
-
document.documentElement.classList.add(ctorOld.action!.replace(/\//g, '-'))
|
|
483
|
-
|
|
484
|
-
manager.setupStyles(undefined, oldActivity)
|
|
485
|
-
|
|
486
|
-
assert.isFalse(document.documentElement.classList.contains(ctorOld.name.toLowerCase()))
|
|
487
|
-
assert.isFalse(document.documentElement.classList.contains(ctorOld.action!.replace(/\//g, '-')))
|
|
488
|
-
})
|
|
489
|
-
})
|
|
490
|
-
|
|
491
|
-
describe('navigateBack()', () => {
|
|
492
|
-
it('finishes current activity if stack has more than one activity', async () => {
|
|
493
|
-
await manager.startActivity({ action: TestActivity.action })
|
|
494
|
-
await manager.startActivity({ action: TestActivity2.action }) // Now 2 activities
|
|
495
|
-
|
|
496
|
-
const finishActivitySpy = sinon.spy(manager, 'finishActivity')
|
|
497
|
-
const activity2 = manager.getCurrentActivity()!
|
|
498
|
-
|
|
499
|
-
await manager.navigateBack()
|
|
500
|
-
|
|
501
|
-
assert.isTrue(finishActivitySpy.calledOnceWith(activity2))
|
|
502
|
-
assert.instanceOf(manager.getCurrentActivity(), TestActivity) // Back to activity1
|
|
503
|
-
})
|
|
504
|
-
|
|
505
|
-
it('does nothing if only one or no activity on stack', async () => {
|
|
506
|
-
const finishActivitySpy = sinon.spy(manager, 'finishActivity')
|
|
507
|
-
|
|
508
|
-
await manager.navigateBack() // No activities
|
|
509
|
-
assert.isFalse(finishActivitySpy.called)
|
|
510
|
-
|
|
511
|
-
await manager.startActivity({ action: TestActivity.action }) // One activity
|
|
512
|
-
await manager.navigateBack()
|
|
513
|
-
assert.isFalse(finishActivitySpy.called) // Still one activity, finish not called by navigateBack
|
|
514
|
-
})
|
|
515
|
-
})
|
|
516
|
-
|
|
517
|
-
describe('createRequestCode()', () => {
|
|
518
|
-
it('generates a random number between 1000 and 9999', () => {
|
|
519
|
-
const code = manager.createRequestCode()
|
|
520
|
-
assert.isNumber(code)
|
|
521
|
-
assert.isAtLeast(code, 1000)
|
|
522
|
-
assert.isAtMost(code, 9999)
|
|
523
|
-
})
|
|
524
|
-
|
|
525
|
-
it('generates different codes on subsequent calls (highly likely)', () => {
|
|
526
|
-
const code1 = manager.createRequestCode()
|
|
527
|
-
const code2 = manager.createRequestCode()
|
|
528
|
-
assert.notEqual(code1, code2) // Statistically very unlikely to be equal
|
|
529
|
-
})
|
|
530
|
-
})
|
|
531
|
-
|
|
532
|
-
describe('findActiveActivity()', () => {
|
|
533
|
-
it('returns undefined if no activity with the action is found', () => {
|
|
534
|
-
assert.isUndefined(manager.findActiveActivity(TestActivity.action))
|
|
535
|
-
})
|
|
536
|
-
|
|
537
|
-
it('returns the activity if found in the stack', async () => {
|
|
538
|
-
const intent: Intent = { action: TestActivity.action }
|
|
539
|
-
await manager.startActivity(intent)
|
|
540
|
-
const activity = manager.getCurrentActivity()
|
|
541
|
-
assert.strictEqual(manager.findActiveActivity(TestActivity.action), activity)
|
|
542
|
-
})
|
|
543
|
-
})
|
|
544
|
-
})
|