summaryrefslogtreecommitdiffstats
path: root/polygerrit-ui/app/elements/shared/gr-overlay/gr-overlay_test.ts
diff options
context:
space:
mode:
Diffstat (limited to 'polygerrit-ui/app/elements/shared/gr-overlay/gr-overlay_test.ts')
-rw-r--r--polygerrit-ui/app/elements/shared/gr-overlay/gr-overlay_test.ts90
1 files changed, 90 insertions, 0 deletions
diff --git a/polygerrit-ui/app/elements/shared/gr-overlay/gr-overlay_test.ts b/polygerrit-ui/app/elements/shared/gr-overlay/gr-overlay_test.ts
new file mode 100644
index 0000000000..1a82a8ea50
--- /dev/null
+++ b/polygerrit-ui/app/elements/shared/gr-overlay/gr-overlay_test.ts
@@ -0,0 +1,90 @@
+/**
+ * @license
+ * Copyright (C) 2017 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import '../../../test/common-test-setup-karma';
+import './gr-overlay';
+import {html} from '@polymer/polymer/lib/utils/html-tag';
+import {GrOverlay} from './gr-overlay';
+
+const basicFixture = fixtureFromTemplate(html`
+ <gr-overlay>
+ <div>content</div>
+ </gr-overlay>
+`);
+
+suite('gr-overlay tests', () => {
+ let element: GrOverlay;
+
+ setup(() => {
+ element = basicFixture.instantiate() as GrOverlay;
+ });
+
+ test('popstate listener is attached on open and removed on close', () => {
+ const addEventListenerStub = sinon.stub(window, 'addEventListener');
+ const removeEventListenerStub = sinon.stub(window, 'removeEventListener');
+ element.open();
+ assert.isTrue(addEventListenerStub.called);
+ assert.equal(addEventListenerStub.lastCall.args[0], 'popstate');
+ assert.equal(
+ addEventListenerStub.lastCall.args[1],
+ element._boundHandleClose
+ );
+ element._overlayClosed();
+ assert.isTrue(removeEventListenerStub.called);
+ assert.equal(removeEventListenerStub.lastCall.args[0], 'popstate');
+ assert.equal(
+ removeEventListenerStub.lastCall.args[1],
+ element._boundHandleClose
+ );
+ });
+
+ test('events are fired on fullscreen view', async () => {
+ const isMobileStub = sinon.stub(element, '_isMobile').returns(true as any);
+ const openHandler = sinon.stub();
+ const closeHandler = sinon.stub();
+ element.addEventListener('fullscreen-overlay-opened', openHandler);
+ element.addEventListener('fullscreen-overlay-closed', closeHandler);
+
+ await element.open();
+
+ assert.isTrue(isMobileStub.called);
+ assert.isTrue(element.fullScreenOpen);
+ assert.isTrue(openHandler.called);
+
+ element._overlayClosed();
+ assert.isFalse(element.fullScreenOpen);
+ assert.isTrue(closeHandler.called);
+ });
+
+ test('events are not fired on desktop view', async () => {
+ const isMobileStub = sinon.stub(element, '_isMobile').returns(false as any);
+ const openHandler = sinon.stub();
+ const closeHandler = sinon.stub();
+ element.addEventListener('fullscreen-overlay-opened', openHandler);
+ element.addEventListener('fullscreen-overlay-closed', closeHandler);
+
+ await element.open();
+
+ assert.isTrue(isMobileStub.called);
+ assert.isFalse(element.fullScreenOpen);
+ assert.isFalse(openHandler.called);
+
+ element._overlayClosed();
+ assert.isFalse(element.fullScreenOpen);
+ assert.isFalse(closeHandler.called);
+ });
+});