From db5b3d3a45faa26ffb46349799f25be93d036599 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adri=C3=A0=20Fontcuberta?= Date: Tue, 14 Apr 2020 10:05:34 +0200 Subject: [PATCH 1/2] Install dep --- package-lock.json | 6 ++++++ package.json | 1 + 2 files changed, 7 insertions(+) diff --git a/package-lock.json b/package-lock.json index 399a7d86..ff0f3d49 100644 --- a/package-lock.json +++ b/package-lock.json @@ -12447,6 +12447,12 @@ "integrity": "sha512-2qHaIQr2VLRFoxe2nASzsV6ef4yOOH+Fi9FBOVH6cqeSgUnoyySPZkxzLuzd+RYOQTRpROA0ztTMqxROKSb/nA==", "dev": true }, + "portal-vue": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/portal-vue/-/portal-vue-2.1.7.tgz", + "integrity": "sha512-+yCno2oB3xA7irTt0EU5Ezw22L2J51uKAacE/6hMPMoO/mx3h4rXFkkBkT4GFsMDv/vEe8TNKC3ujJJ0PTwb6g==", + "dev": true + }, "posix-character-classes": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", diff --git a/package.json b/package.json index e3ca5bd8..44131168 100644 --- a/package.json +++ b/package.json @@ -53,6 +53,7 @@ "jest-serializer-vue": "^2.0.2", "kcd-scripts": "^5.4.0", "lodash.merge": "^4.6.2", + "portal-vue": "^2.1.7", "vee-validate": "^2.2.15", "vue": "^2.6.11", "vue-i18n": "^8.15.5", From e79fab95e61fc4c44e3dd5388f513dee76cae981 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adri=C3=A0=20Fontcuberta?= Date: Tue, 14 Apr 2020 10:07:48 +0200 Subject: [PATCH 2/2] Add basic example --- src/__tests__/vue-portal.js | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 src/__tests__/vue-portal.js diff --git a/src/__tests__/vue-portal.js b/src/__tests__/vue-portal.js new file mode 100644 index 00000000..b1fbf422 --- /dev/null +++ b/src/__tests__/vue-portal.js @@ -0,0 +1,30 @@ +import {render, waitFor} from '@testing-library/vue' +import '@testing-library/jest-dom/extend-expect' +import PortalVue from 'portal-vue' + +const PortalComponent = { + template: ` +
+ +

Content rendered wherever the portal-target is located.

+
+ + +
`, +} + +test('portal', async () => { + const {getByTestId} = render(PortalComponent, {}, vue => { + vue.use(PortalVue) + }) + + // wait until PortalVue has removed content from the source element + // and moved it to the target one. + await waitFor(() => { + expect(getByTestId('portal')).toBeEmpty() + }) + + expect(getByTestId('target')).toHaveTextContent( + 'Content rendered wherever the portal-target is located.', + ) +})