creevey 0.9.0-beta.1 → 0.9.0-beta.3
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/CHANGELOG.md +33 -0
- package/README.md +9 -1
- package/addon/README.md +3 -0
- package/addon/package.json +4 -0
- package/docs/config.md +29 -26
- package/jest.config.js +6 -0
- package/lib/cjs/cli.js +5 -0
- package/lib/cjs/client/addon/Manager.js +264 -0
- package/lib/cjs/client/addon/components/Addon.js +55 -0
- package/lib/cjs/client/addon/components/Icons.js +46 -0
- package/lib/cjs/client/addon/components/Panel.js +72 -0
- package/lib/cjs/client/addon/components/TestSelect.js +65 -0
- package/lib/cjs/client/addon/components/Tools.js +95 -0
- package/lib/cjs/client/addon/decorator.js +11 -0
- package/lib/cjs/client/addon/index.js +31 -0
- package/lib/cjs/client/addon/preset.ie11.js +74 -0
- package/lib/cjs/client/addon/preset.js +62 -0
- package/lib/cjs/client/addon/readyForCapture.js +12 -0
- package/lib/cjs/client/addon/register.js +72 -0
- package/lib/cjs/client/addon/utils.js +42 -0
- package/lib/cjs/client/addon/withCreevey.js +350 -0
- package/lib/cjs/client/shared/components/ImagesView/BlendView.js +87 -0
- package/lib/cjs/client/shared/components/ImagesView/ImagesView.js +92 -0
- package/lib/cjs/client/shared/components/ImagesView/SideBySideView.js +154 -0
- package/lib/cjs/client/shared/components/ImagesView/SlideView.js +166 -0
- package/lib/cjs/client/shared/components/ImagesView/SwapView.js +91 -0
- package/lib/cjs/client/shared/components/ImagesView/index.js +45 -0
- package/lib/cjs/client/shared/components/PageFooter/PageFooter.js +50 -0
- package/lib/cjs/client/shared/components/PageFooter/Paging.js +94 -0
- package/lib/cjs/client/shared/components/PageHeader/ImagePreview.js +82 -0
- package/lib/cjs/client/shared/components/PageHeader/PageHeader.js +119 -0
- package/lib/cjs/client/shared/components/ResultsPage.js +143 -0
- package/lib/cjs/client/shared/creeveyClientApi.js +76 -0
- package/lib/cjs/client/shared/helpers.js +411 -0
- package/lib/cjs/client/shared/viewMode.js +17 -0
- package/lib/cjs/client/web/142.js +2 -0
- package/lib/cjs/client/web/142.js.LICENSE.txt +12 -0
- package/lib/cjs/client/web/32.js +1 -0
- package/lib/cjs/client/web/551.js +1 -0
- package/lib/cjs/client/web/566.js +2 -0
- package/lib/cjs/client/web/566.js.LICENSE.txt +31 -0
- package/lib/cjs/client/web/691.js +2 -0
- package/lib/cjs/client/web/691.js.LICENSE.txt +8 -0
- package/lib/cjs/client/web/725.js +1 -0
- package/lib/cjs/client/web/index.html +19 -0
- package/lib/cjs/client/web/main.js +2 -38
- package/lib/cjs/client/web/main.js.LICENSE.txt +49 -0
- package/lib/cjs/creevey.js +69 -0
- package/lib/cjs/index.js +62 -0
- package/lib/cjs/server/config.js +94 -0
- package/lib/cjs/server/docker.js +146 -0
- package/lib/cjs/server/extract.js +46 -0
- package/lib/cjs/server/index.js +83 -0
- package/lib/cjs/server/loaders/babel/creevey-plugin.js +86 -0
- package/lib/cjs/server/loaders/babel/helpers.js +469 -0
- package/lib/cjs/server/loaders/babel/register.js +124 -0
- package/lib/cjs/server/loaders/hooks/mdx.js +30 -0
- package/lib/cjs/server/loaders/hooks/svelte.js +65 -0
- package/lib/cjs/server/loaders/webpack/compile.js +269 -0
- package/lib/cjs/server/loaders/webpack/creevey-loader.js +172 -0
- package/lib/cjs/server/loaders/webpack/dummy-hmr.js +39 -0
- package/lib/cjs/server/loaders/webpack/mdx-loader.js +72 -0
- package/lib/cjs/server/loaders/webpack/start.js +41 -0
- package/lib/cjs/server/logger.js +48 -0
- package/lib/cjs/server/master/api.js +71 -0
- package/lib/cjs/server/master/index.js +146 -0
- package/lib/cjs/server/master/master.js +57 -0
- package/lib/cjs/server/master/pool.js +197 -0
- package/lib/cjs/server/master/runner.js +281 -0
- package/lib/cjs/server/master/server.js +131 -0
- package/lib/cjs/server/messages.js +264 -0
- package/lib/cjs/server/selenium/browser.js +656 -0
- package/lib/cjs/server/selenium/index.js +31 -0
- package/lib/cjs/server/selenium/selenoid.js +172 -0
- package/lib/cjs/server/stories.js +153 -0
- package/lib/cjs/server/storybook/entry.js +53 -0
- package/lib/cjs/server/storybook/helpers.js +158 -0
- package/lib/cjs/server/storybook/providers/browser.js +74 -0
- package/lib/cjs/server/storybook/providers/hybrid.js +84 -0
- package/lib/cjs/server/storybook/providers/nodejs.js +237 -0
- package/lib/cjs/server/testsFiles/parser.js +72 -0
- package/lib/cjs/server/testsFiles/register.js +48 -0
- package/lib/cjs/server/update.js +79 -0
- package/lib/cjs/server/utils.js +176 -0
- package/lib/cjs/server/worker/chai-image.js +142 -0
- package/lib/cjs/server/worker/helpers.js +69 -0
- package/lib/cjs/server/worker/index.js +15 -0
- package/lib/cjs/server/worker/reporter.js +108 -0
- package/lib/cjs/server/worker/worker.js +268 -0
- package/lib/cjs/shared/index.js +101 -0
- package/lib/cjs/shared/serializeRegExp.js +42 -0
- package/lib/cjs/types.js +74 -0
- package/lib/esm/cli.js +4 -0
- package/lib/esm/client/addon/Manager.js +248 -0
- package/lib/esm/client/addon/components/Addon.js +39 -0
- package/lib/esm/client/addon/components/Icons.js +31 -0
- package/lib/esm/client/addon/components/Panel.js +53 -0
- package/lib/esm/client/addon/components/TestSelect.js +51 -0
- package/lib/esm/client/addon/components/Tools.js +74 -0
- package/lib/esm/client/addon/decorator.js +2 -0
- package/lib/esm/client/addon/index.js +2 -0
- package/lib/esm/client/addon/preset.ie11.js +59 -0
- package/lib/esm/client/addon/preset.js +41 -0
- package/lib/esm/client/addon/readyForCapture.js +5 -0
- package/lib/esm/client/addon/register.js +51 -0
- package/lib/esm/client/addon/utils.js +32 -0
- package/lib/esm/client/addon/withCreevey.js +323 -0
- package/lib/esm/client/shared/components/ImagesView/BlendView.js +67 -0
- package/lib/esm/client/shared/components/ImagesView/ImagesView.js +69 -0
- package/lib/esm/client/shared/components/ImagesView/SideBySideView.js +131 -0
- package/lib/esm/client/shared/components/ImagesView/SlideView.js +143 -0
- package/lib/esm/client/shared/components/ImagesView/SwapView.js +71 -0
- package/lib/esm/client/shared/components/ImagesView/index.js +5 -0
- package/lib/esm/client/shared/components/PageFooter/PageFooter.js +36 -0
- package/lib/esm/client/shared/components/PageFooter/Paging.js +80 -0
- package/lib/esm/client/shared/components/PageHeader/ImagePreview.js +68 -0
- package/lib/esm/client/shared/components/PageHeader/PageHeader.js +97 -0
- package/lib/esm/client/shared/components/ResultsPage.js +115 -0
- package/lib/esm/client/shared/creeveyClientApi.js +67 -0
- package/lib/esm/client/shared/helpers.js +353 -0
- package/lib/esm/client/shared/viewMode.js +6 -0
- package/lib/esm/creevey.js +54 -0
- package/lib/esm/index.js +5 -0
- package/lib/esm/server/config.js +71 -0
- package/lib/esm/server/docker.js +123 -0
- package/lib/esm/server/extract.js +32 -0
- package/lib/esm/server/index.js +64 -0
- package/lib/esm/server/loaders/babel/creevey-plugin.js +72 -0
- package/lib/esm/server/loaders/babel/helpers.js +452 -0
- package/lib/esm/server/loaders/babel/register.js +103 -0
- package/lib/esm/server/loaders/hooks/mdx.js +15 -0
- package/lib/esm/server/loaders/hooks/svelte.js +49 -0
- package/lib/esm/server/loaders/webpack/compile.js +246 -0
- package/lib/esm/server/loaders/webpack/creevey-loader.js +152 -0
- package/lib/esm/server/loaders/webpack/dummy-hmr.js +32 -0
- package/lib/esm/server/loaders/webpack/mdx-loader.js +58 -0
- package/lib/esm/server/loaders/webpack/start.js +27 -0
- package/lib/esm/server/logger.js +20 -0
- package/lib/esm/server/master/api.js +60 -0
- package/lib/esm/server/master/index.js +125 -0
- package/lib/esm/server/master/master.js +38 -0
- package/lib/esm/server/master/pool.js +176 -0
- package/lib/esm/server/master/runner.js +259 -0
- package/lib/esm/server/master/server.js +107 -0
- package/lib/esm/server/messages.js +232 -0
- package/lib/esm/server/selenium/browser.js +623 -0
- package/lib/esm/server/selenium/index.js +2 -0
- package/lib/esm/server/selenium/selenoid.js +149 -0
- package/lib/esm/server/stories.js +135 -0
- package/lib/esm/server/storybook/entry.js +27 -0
- package/lib/esm/server/storybook/helpers.js +97 -0
- package/lib/esm/server/storybook/providers/browser.js +60 -0
- package/lib/esm/server/storybook/providers/hybrid.js +64 -0
- package/lib/esm/server/storybook/providers/nodejs.js +216 -0
- package/lib/esm/server/testsFiles/parser.js +50 -0
- package/lib/esm/server/testsFiles/register.js +35 -0
- package/lib/esm/server/update.js +61 -0
- package/lib/esm/server/utils.js +133 -0
- package/lib/esm/server/worker/chai-image.js +130 -0
- package/lib/esm/server/worker/helpers.js +60 -0
- package/lib/esm/server/worker/index.js +1 -0
- package/lib/esm/server/worker/reporter.js +86 -0
- package/lib/esm/server/worker/worker.js +238 -0
- package/lib/esm/shared/index.js +78 -0
- package/lib/esm/shared/serializeRegExp.js +24 -0
- package/lib/esm/types.js +43 -0
- package/lib/types/cli.d.ts +1 -1
- package/lib/types/client/addon/Manager.d.ts +37 -37
- package/lib/types/client/addon/components/Addon.d.ts +8 -8
- package/lib/types/client/addon/components/Icons.d.ts +7 -7
- package/lib/types/client/addon/components/Panel.d.ts +9 -9
- package/lib/types/client/addon/components/TestSelect.d.ts +8 -9
- package/lib/types/client/addon/components/Tools.d.ts +6 -6
- package/lib/types/client/addon/decorator.d.ts +1 -1
- package/lib/types/client/addon/index.d.ts +2 -0
- package/lib/types/client/addon/preset.d.ts +23 -24
- package/lib/types/client/addon/preset.ie11.d.ts +10 -0
- package/lib/types/client/addon/readyForCapture.d.ts +6 -6
- package/lib/types/client/addon/register.d.ts +3 -3
- package/lib/types/client/addon/utils.d.ts +3 -2
- package/lib/types/client/addon/withCreevey.d.ts +24 -24
- package/lib/types/client/shared/components/ImagesView/BlendView.d.ts +3 -3
- package/lib/types/client/shared/components/ImagesView/ImagesView.d.ts +24 -25
- package/lib/types/client/shared/components/ImagesView/SideBySideView.d.ts +3 -3
- package/lib/types/client/shared/components/ImagesView/SlideView.d.ts +3 -3
- package/lib/types/client/shared/components/ImagesView/SwapView.d.ts +3 -3
- package/lib/types/client/shared/components/ImagesView/index.d.ts +5 -5
- package/lib/types/client/shared/components/PageFooter/PageFooter.d.ts +8 -9
- package/lib/types/client/shared/components/PageFooter/Paging.d.ts +7 -8
- package/lib/types/client/shared/components/PageHeader/ImagePreview.d.ts +12 -12
- package/lib/types/client/shared/components/PageHeader/PageHeader.d.ts +16 -17
- package/lib/types/client/shared/components/ResultsPage.d.ts +18 -18
- package/lib/types/client/shared/creeveyClientApi.d.ts +9 -9
- package/lib/types/client/shared/helpers.d.ts +46 -46
- package/lib/types/client/shared/viewMode.d.ts +4 -4
- package/lib/types/client/web/CreeveyApp.d.ts +11 -12
- package/lib/types/client/web/CreeveyContext.d.ts +11 -11
- package/lib/types/client/web/CreeveyLoader.d.ts +2 -3
- package/lib/types/client/web/CreeveyView/SideBar/Checkbox.d.ts +19 -19
- package/lib/types/client/web/CreeveyView/SideBar/Search.d.ts +6 -6
- package/lib/types/client/web/CreeveyView/SideBar/SideBar.d.ts +14 -14
- package/lib/types/client/web/CreeveyView/SideBar/SideBarHeader.d.ts +12 -13
- package/lib/types/client/web/CreeveyView/SideBar/SuiteLink.d.ts +33 -33
- package/lib/types/client/web/CreeveyView/SideBar/TestLink.d.ts +7 -8
- package/lib/types/client/web/CreeveyView/SideBar/TestStatusIcon.d.ts +10 -10
- package/lib/types/client/web/CreeveyView/SideBar/TestsStatus.d.ts +9 -9
- package/lib/types/client/web/CreeveyView/SideBar/Toggle.d.ts +6 -6
- package/lib/types/client/web/CreeveyView/SideBar/index.d.ts +1 -1
- package/lib/types/client/web/KeyboardEventsContext.d.ts +13 -13
- package/lib/types/client/web/index.d.ts +4 -4
- package/lib/types/creevey.d.ts +1 -1
- package/lib/types/index.d.ts +1 -4
- package/lib/types/server/config.d.ts +4 -4
- package/lib/types/server/docker.d.ts +7 -7
- package/lib/types/server/extract.d.ts +2 -2
- package/lib/types/server/index.d.ts +2 -2
- package/lib/types/server/loaders/babel/creevey-plugin.d.ts +1 -1
- package/lib/types/server/loaders/babel/helpers.d.ts +19 -19
- package/lib/types/server/loaders/babel/register.d.ts +5 -5
- package/lib/types/server/loaders/hooks/mdx.d.ts +1 -1
- package/lib/types/server/loaders/hooks/svelte.d.ts +1 -1
- package/lib/types/server/loaders/webpack/compile.d.ts +2 -2
- package/lib/types/server/loaders/webpack/creevey-loader.d.ts +4 -2
- package/lib/types/server/loaders/webpack/dummy-hmr.d.ts +10 -10
- package/lib/types/server/loaders/webpack/mdx-loader.d.ts +6 -6
- package/lib/types/server/loaders/webpack/start.d.ts +1 -1
- package/lib/types/server/logger.d.ts +10 -6
- package/lib/types/server/master/api.d.ts +7 -7
- package/lib/types/server/master/index.d.ts +3 -3
- package/lib/types/server/master/master.d.ts +7 -7
- package/lib/types/server/master/pool.d.ts +31 -31
- package/lib/types/server/master/runner.d.ts +26 -26
- package/lib/types/server/master/server.d.ts +2 -2
- package/lib/types/server/messages.d.ts +27 -27
- package/lib/types/server/selenium/browser.d.ts +17 -17
- package/lib/types/server/selenium/index.d.ts +2 -2
- package/lib/types/server/selenium/selenoid.d.ts +3 -3
- package/lib/types/server/stories.d.ts +8 -8
- package/lib/types/server/storybook/entry.d.ts +17 -18
- package/lib/types/server/storybook/helpers.d.ts +24 -24
- package/lib/types/server/storybook/providers/browser.d.ts +4 -4
- package/lib/types/server/storybook/providers/hybrid.d.ts +4 -4
- package/lib/types/server/storybook/providers/nodejs.d.ts +9 -9
- package/lib/types/server/testsFiles/parser.d.ts +12 -12
- package/lib/types/server/testsFiles/register.d.ts +2 -2
- package/lib/types/server/update.d.ts +2 -2
- package/lib/types/server/utils.d.ts +24 -20
- package/lib/types/server/worker/chai-image.d.ts +6 -6
- package/lib/types/server/worker/helpers.d.ts +8 -8
- package/lib/types/server/worker/index.d.ts +1 -1
- package/lib/types/server/worker/reporter.d.ts +8 -8
- package/lib/types/server/worker/worker.d.ts +4 -4
- package/lib/types/{shared.d.ts → shared/index.d.ts} +7 -16
- package/lib/types/shared/serializeRegExp.d.ts +9 -0
- package/lib/types/types.d.ts +489 -489
- package/package.json +114 -102
- package/preset/ie11.js +5 -0
- package/{preset.js → preset/index.js} +2 -2
- package/types/mdx.d.ts +3 -2
- package/lib/cjs/client/web/1.js +0 -13
- package/lib/cjs/client/web/2.js +0 -1
- package/storybook-static/stories.json +0 -21
@@ -0,0 +1,65 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.default = TestSelect;
|
7
|
+
|
8
|
+
var _components = require("@storybook/components");
|
9
|
+
|
10
|
+
var _theming = require("@storybook/theming");
|
11
|
+
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
13
|
+
|
14
|
+
var _utils = require("../utils");
|
15
|
+
|
16
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
17
|
+
|
18
|
+
const LinkIconContainer = _theming.styled.span(_ref => {
|
19
|
+
let {
|
20
|
+
theme
|
21
|
+
} = _ref;
|
22
|
+
return {
|
23
|
+
display: 'inline-block',
|
24
|
+
width: '20px',
|
25
|
+
color: theme.color.defaultText,
|
26
|
+
textAlign: 'center'
|
27
|
+
};
|
28
|
+
});
|
29
|
+
|
30
|
+
function TestSelect(props) {
|
31
|
+
var _props$tests$find$tes, _props$tests$find;
|
32
|
+
|
33
|
+
const testName = (_props$tests$find$tes = (_props$tests$find = props.tests.find(x => x.id === props.selectedTestId)) === null || _props$tests$find === void 0 ? void 0 : _props$tests$find.testName) !== null && _props$tests$find$tes !== void 0 ? _props$tests$find$tes : '';
|
34
|
+
return /*#__PURE__*/_react.default.createElement(_components.WithTooltip, {
|
35
|
+
trigger: "click",
|
36
|
+
placement: "bottom",
|
37
|
+
closeOnClick: true,
|
38
|
+
tooltip: _ref2 => {
|
39
|
+
let {
|
40
|
+
onHide
|
41
|
+
} = _ref2;
|
42
|
+
return /*#__PURE__*/_react.default.createElement(_components.TooltipLinkList, {
|
43
|
+
links: props.tests.map(x => {
|
44
|
+
var _x$testName;
|
45
|
+
|
46
|
+
return {
|
47
|
+
id: x.id,
|
48
|
+
title: (_x$testName = x.testName) !== null && _x$testName !== void 0 ? _x$testName : '',
|
49
|
+
active: props.selectedTestId === x.id,
|
50
|
+
onClick: () => {
|
51
|
+
props.onChangeTest(x.id);
|
52
|
+
onHide();
|
53
|
+
},
|
54
|
+
left: /*#__PURE__*/_react.default.createElement(LinkIconContainer, null, (0, _utils.getEmojiByTestStatus)(x.status, x.skip))
|
55
|
+
};
|
56
|
+
})
|
57
|
+
});
|
58
|
+
}
|
59
|
+
}, /*#__PURE__*/_react.default.createElement(_components.Button, {
|
60
|
+
outline: true,
|
61
|
+
small: true
|
62
|
+
}, /*#__PURE__*/_react.default.createElement(_components.Icons, {
|
63
|
+
icon: "menu"
|
64
|
+
}), testName));
|
65
|
+
}
|
@@ -0,0 +1,95 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.Tools = void 0;
|
7
|
+
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
9
|
+
|
10
|
+
var _components = require("@storybook/components");
|
11
|
+
|
12
|
+
var _Icons = require("./Icons");
|
13
|
+
|
14
|
+
var _qs = require("qs");
|
15
|
+
|
16
|
+
var _theming = require("@storybook/theming");
|
17
|
+
|
18
|
+
var _types = require("../../../types");
|
19
|
+
|
20
|
+
var _helpers = require("../../shared/helpers");
|
21
|
+
|
22
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
23
|
+
|
24
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
25
|
+
|
26
|
+
const Button = (0, _theming.styled)(_components.IconButton)({
|
27
|
+
'&:disabled': {
|
28
|
+
opacity: 0.5,
|
29
|
+
cursor: 'default'
|
30
|
+
},
|
31
|
+
'&:disabled:hover': {
|
32
|
+
color: 'inherit'
|
33
|
+
}
|
34
|
+
});
|
35
|
+
|
36
|
+
const Tools = _ref => {
|
37
|
+
let {
|
38
|
+
manager
|
39
|
+
} = _ref;
|
40
|
+
const [buttonClicked, setButtonClicked] = (0, _react.useState)();
|
41
|
+
const [isRunning, setRunning] = (0, _react.useState)(manager.status.isRunning);
|
42
|
+
const forceUpdate = (0, _helpers.useForceUpdate)();
|
43
|
+
const test = manager.getCurrentTest();
|
44
|
+
(0, _react.useEffect)(() => {
|
45
|
+
const unsubscribe = manager.onChangeTest(() => {
|
46
|
+
forceUpdate();
|
47
|
+
});
|
48
|
+
return unsubscribe;
|
49
|
+
}, [manager, forceUpdate]);
|
50
|
+
(0, _react.useEffect)(() => {
|
51
|
+
const unsubscribe = manager.onUpdateStatus(_ref2 => {
|
52
|
+
let {
|
53
|
+
isRunning
|
54
|
+
} = _ref2;
|
55
|
+
if ((0, _types.isDefined)(isRunning)) setRunning(isRunning);
|
56
|
+
});
|
57
|
+
return unsubscribe;
|
58
|
+
}, [manager]);
|
59
|
+
if (!test) return null;
|
60
|
+
|
61
|
+
function renderButton(type, title, onClick, icon) {
|
62
|
+
const handleClick = () => {
|
63
|
+
setButtonClicked(type);
|
64
|
+
onClick();
|
65
|
+
};
|
66
|
+
|
67
|
+
const disabled = isRunning && buttonClicked != null && buttonClicked !== type;
|
68
|
+
return /*#__PURE__*/_react.default.createElement(Button, {
|
69
|
+
onClick: () => {
|
70
|
+
isRunning ? manager.onStop() : handleClick();
|
71
|
+
},
|
72
|
+
title: disabled ? '' : title,
|
73
|
+
disabled: disabled
|
74
|
+
}, buttonClicked === type && isRunning ? /*#__PURE__*/_react.default.createElement(_components.Icons, {
|
75
|
+
icon: 'stop'
|
76
|
+
}) : icon);
|
77
|
+
}
|
78
|
+
|
79
|
+
return /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement(_components.IconButton, {
|
80
|
+
href: "http://localhost:".concat(__CREEVEY_CLIENT_PORT__ || __CREEVEY_SERVER_PORT__, "/?").concat((0, _qs.stringify)({
|
81
|
+
testPath: (0, _helpers.getTestPath)(test)
|
82
|
+
})),
|
83
|
+
target: "_blank",
|
84
|
+
title: "Show in Creevey UI"
|
85
|
+
}, /*#__PURE__*/_react.default.createElement(_components.Icons, {
|
86
|
+
icon: "sharealt"
|
87
|
+
})), /*#__PURE__*/_react.default.createElement(_components.Separator, null), renderButton('RunAll', 'Run all', manager.onStartAllTests, /*#__PURE__*/_react.default.createElement(_Icons.ForwardIcon, null)), renderButton('RunStoryTests', 'Run all story tests', manager.onStartAllStoryTests, /*#__PURE__*/_react.default.createElement(_Icons.NextIcon, {
|
88
|
+
width: 15,
|
89
|
+
height: 11
|
90
|
+
})), renderButton('RunTest', 'Run', manager.onStart, /*#__PURE__*/_react.default.createElement(_components.Icons, {
|
91
|
+
icon: "play"
|
92
|
+
})));
|
93
|
+
};
|
94
|
+
|
95
|
+
exports.Tools = Tools;
|
@@ -0,0 +1,11 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.decorators = void 0;
|
7
|
+
|
8
|
+
var _withCreevey = require("./withCreevey");
|
9
|
+
|
10
|
+
const decorators = [(0, _withCreevey.withCreevey)()];
|
11
|
+
exports.decorators = decorators;
|
@@ -0,0 +1,31 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
|
7
|
+
var _withCreevey = require("./withCreevey");
|
8
|
+
|
9
|
+
Object.keys(_withCreevey).forEach(function (key) {
|
10
|
+
if (key === "default" || key === "__esModule") return;
|
11
|
+
if (key in exports && exports[key] === _withCreevey[key]) return;
|
12
|
+
Object.defineProperty(exports, key, {
|
13
|
+
enumerable: true,
|
14
|
+
get: function () {
|
15
|
+
return _withCreevey[key];
|
16
|
+
}
|
17
|
+
});
|
18
|
+
});
|
19
|
+
|
20
|
+
var _readyForCapture = require("./readyForCapture");
|
21
|
+
|
22
|
+
Object.keys(_readyForCapture).forEach(function (key) {
|
23
|
+
if (key === "default" || key === "__esModule") return;
|
24
|
+
if (key in exports && exports[key] === _readyForCapture[key]) return;
|
25
|
+
Object.defineProperty(exports, key, {
|
26
|
+
enumerable: true,
|
27
|
+
get: function () {
|
28
|
+
return _readyForCapture[key];
|
29
|
+
}
|
30
|
+
});
|
31
|
+
});
|
@@ -0,0 +1,74 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.webpack = exports.managerWebpack = exports.babel = void 0;
|
7
|
+
const ie11Preset = ['@babel/preset-env', {
|
8
|
+
targets: {
|
9
|
+
ie: '11'
|
10
|
+
}
|
11
|
+
}];
|
12
|
+
|
13
|
+
const babel = config => {
|
14
|
+
const {
|
15
|
+
presets = []
|
16
|
+
} = config;
|
17
|
+
return { ...config,
|
18
|
+
presets: [...(presets || []), ie11Preset]
|
19
|
+
};
|
20
|
+
};
|
21
|
+
|
22
|
+
exports.babel = babel;
|
23
|
+
const nodeModulesThatNeedToBeParsedBecauseTheyExposeES6 = ['creevey', '@testing-library'];
|
24
|
+
const include = new RegExp("[\\\\/](".concat(nodeModulesThatNeedToBeParsedBecauseTheyExposeES6.join('|'), ")"));
|
25
|
+
const es6Loader = {
|
26
|
+
test: /\.js$/,
|
27
|
+
use: [{
|
28
|
+
loader: require.resolve('babel-loader'),
|
29
|
+
options: {
|
30
|
+
presets: [ie11Preset]
|
31
|
+
}
|
32
|
+
}],
|
33
|
+
include
|
34
|
+
};
|
35
|
+
|
36
|
+
const managerWebpack = function () {
|
37
|
+
var _webpackConfig$module, _webpackConfig$module2;
|
38
|
+
|
39
|
+
let webpackConfig = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
40
|
+
return { ...webpackConfig,
|
41
|
+
module: { ...webpackConfig.module,
|
42
|
+
rules: [...((_webpackConfig$module = (_webpackConfig$module2 = webpackConfig.module) === null || _webpackConfig$module2 === void 0 ? void 0 : _webpackConfig$module2.rules) !== null && _webpackConfig$module !== void 0 ? _webpackConfig$module : []), es6Loader]
|
43
|
+
}
|
44
|
+
};
|
45
|
+
};
|
46
|
+
|
47
|
+
exports.managerWebpack = managerWebpack;
|
48
|
+
|
49
|
+
const webpack = function () {
|
50
|
+
var _webpackConfig$module3, _webpackConfig$module4;
|
51
|
+
|
52
|
+
let webpackConfig = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
53
|
+
const {
|
54
|
+
entry
|
55
|
+
} = webpackConfig;
|
56
|
+
const polyfills = [require.resolve('whatwg-fetch')];
|
57
|
+
|
58
|
+
if (Array.isArray(entry)) {
|
59
|
+
polyfills.forEach(polyfill => {
|
60
|
+
if (!entry.includes(polyfill)) {
|
61
|
+
entry.unshift(polyfill);
|
62
|
+
}
|
63
|
+
});
|
64
|
+
}
|
65
|
+
|
66
|
+
return { ...webpackConfig,
|
67
|
+
entry,
|
68
|
+
module: { ...webpackConfig.module,
|
69
|
+
rules: [...((_webpackConfig$module3 = (_webpackConfig$module4 = webpackConfig.module) === null || _webpackConfig$module4 === void 0 ? void 0 : _webpackConfig$module4.rules) !== null && _webpackConfig$module3 !== void 0 ? _webpackConfig$module3 : []), es6Loader]
|
70
|
+
}
|
71
|
+
};
|
72
|
+
};
|
73
|
+
|
74
|
+
exports.webpack = webpack;
|
@@ -0,0 +1,62 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.config = config;
|
7
|
+
exports.managerEntries = managerEntries;
|
8
|
+
exports.managerWebpack = managerWebpack;
|
9
|
+
|
10
|
+
var _path = _interopRequireDefault(require("path"));
|
11
|
+
|
12
|
+
var _shelljs = require("shelljs");
|
13
|
+
|
14
|
+
var _webpack = require("webpack");
|
15
|
+
|
16
|
+
var _helpers = require("../../server/storybook/helpers");
|
17
|
+
|
18
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
19
|
+
|
20
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
21
|
+
|
22
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
23
|
+
|
24
|
+
function config() {
|
25
|
+
let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
26
|
+
return [...entry, require.resolve('./decorator')];
|
27
|
+
}
|
28
|
+
|
29
|
+
function managerEntries() {
|
30
|
+
let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
31
|
+
return [...entry, require.resolve('./register')];
|
32
|
+
}
|
33
|
+
|
34
|
+
function managerWebpack(config, options) {
|
35
|
+
var _options$presets$appl, _options$presets;
|
36
|
+
|
37
|
+
// TODO How to execute with non-webpack bundlers
|
38
|
+
if (options.configType == 'PRODUCTION' && options.skipExtract != true) {
|
39
|
+
const args = [];
|
40
|
+
if (options.creeveyPreExtract) args.push("--require \"".concat(options.creeveyPreExtract, "\""));
|
41
|
+
args.push(_path.default.join(__dirname, '../../cli'));
|
42
|
+
args.push("--extract \"".concat(options.outputDir, "\""));
|
43
|
+
if (options.creeveyConfigPath) args.push("--config \"".concat(options.creeveyConfigPath, "\""));
|
44
|
+
(0, _shelljs.exec)("node ".concat(args.join(' ')), {
|
45
|
+
async: true
|
46
|
+
});
|
47
|
+
}
|
48
|
+
|
49
|
+
return ((_options$presets$appl = (_options$presets = options.presets) === null || _options$presets === void 0 ? void 0 : _options$presets.apply('webpackInstance')) !== null && _options$presets$appl !== void 0 ? _options$presets$appl : Promise.resolve(undefined)).then(webpack => webpack !== null && webpack !== void 0 ? webpack : Promise.resolve("".concat((0, _helpers.resolveFromStorybookCoreServer)('webpack'))).then(s => _interopRequireWildcard(require(s)))).then(webpack => {
|
50
|
+
var _config$plugins, _options$creeveyPort;
|
51
|
+
|
52
|
+
const {
|
53
|
+
DefinePlugin = _webpack.DefinePlugin
|
54
|
+
} = webpack !== null && webpack !== void 0 ? webpack : {};
|
55
|
+
(_config$plugins = config.plugins) === null || _config$plugins === void 0 ? void 0 : _config$plugins.push(new DefinePlugin({
|
56
|
+
__CREEVEY_SERVER_HOST__: options.creeveyHost,
|
57
|
+
__CREEVEY_SERVER_PORT__: (_options$creeveyPort = options.creeveyPort) !== null && _options$creeveyPort !== void 0 ? _options$creeveyPort : 3000,
|
58
|
+
__CREEVEY_CLIENT_PORT__: options.clientPort
|
59
|
+
}));
|
60
|
+
return config;
|
61
|
+
});
|
62
|
+
}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.readyForCapture = readyForCapture;
|
7
|
+
|
8
|
+
function readyForCapture() {
|
9
|
+
var _window$__CREEVEY_SET, _window;
|
10
|
+
|
11
|
+
(_window$__CREEVEY_SET = (_window = window).__CREEVEY_SET_READY_FOR_CAPTURE__) === null || _window$__CREEVEY_SET === void 0 ? void 0 : _window$__CREEVEY_SET.call(_window);
|
12
|
+
}
|
@@ -0,0 +1,72 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.ADDON_ID = void 0;
|
7
|
+
exports.registerCreeveyPanels = registerCreeveyPanels;
|
8
|
+
|
9
|
+
var _addons = require("@storybook/addons");
|
10
|
+
|
11
|
+
var _react = _interopRequireDefault(require("react"));
|
12
|
+
|
13
|
+
var _Addon = require("./components/Addon");
|
14
|
+
|
15
|
+
var _Tools = require("./components/Tools");
|
16
|
+
|
17
|
+
var _Manager = require("./Manager");
|
18
|
+
|
19
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
20
|
+
|
21
|
+
const ADDON_ID = 'creevey';
|
22
|
+
exports.ADDON_ID = ADDON_ID;
|
23
|
+
|
24
|
+
_addons.addons.register(ADDON_ID, api => {
|
25
|
+
void registerCreeveyPanels(api);
|
26
|
+
});
|
27
|
+
|
28
|
+
async function registerCreeveyPanels(storybookApi) {
|
29
|
+
const manager = new _Manager.CreeveyManager(storybookApi);
|
30
|
+
|
31
|
+
_addons.addons.addPanel("".concat(ADDON_ID, "/panel/run"), {
|
32
|
+
title: "Creevey/Run",
|
33
|
+
match: _ref => {
|
34
|
+
let {
|
35
|
+
viewMode
|
36
|
+
} = _ref;
|
37
|
+
return !!(viewMode && /^story$/.exec(viewMode));
|
38
|
+
},
|
39
|
+
type: _addons.types.TOOL,
|
40
|
+
// eslint-disable-next-line react/display-name
|
41
|
+
render: () => /*#__PURE__*/_react.default.createElement(_Tools.Tools, {
|
42
|
+
manager
|
43
|
+
})
|
44
|
+
});
|
45
|
+
|
46
|
+
await manager.initAll();
|
47
|
+
const browsers = manager.getBrowsers();
|
48
|
+
browsers.forEach(browser => {
|
49
|
+
const panelId = "".concat(ADDON_ID, "/panel/").concat(browser);
|
50
|
+
const title = manager.getTabTitle(browser);
|
51
|
+
|
52
|
+
_addons.addons.addPanel(panelId, {
|
53
|
+
title,
|
54
|
+
type: _addons.types.PANEL,
|
55
|
+
paramKey: browser,
|
56
|
+
// NOTE key = PANEL_ID needs to correct render button in addons panel
|
57
|
+
// eslint-disable-next-line react/display-name
|
58
|
+
render: _ref2 => {
|
59
|
+
let {
|
60
|
+
active,
|
61
|
+
key
|
62
|
+
} = _ref2;
|
63
|
+
return /*#__PURE__*/_react.default.createElement(_Addon.Addon, {
|
64
|
+
active,
|
65
|
+
key,
|
66
|
+
manager,
|
67
|
+
browser
|
68
|
+
});
|
69
|
+
}
|
70
|
+
});
|
71
|
+
});
|
72
|
+
}
|
@@ -0,0 +1,42 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.getEmojiByTestStatus = getEmojiByTestStatus;
|
7
|
+
exports.isInternetExplorer = void 0;
|
8
|
+
|
9
|
+
function getEmojiByTestStatus(status) {
|
10
|
+
let skip = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
11
|
+
|
12
|
+
switch (status) {
|
13
|
+
case 'failed':
|
14
|
+
{
|
15
|
+
return '❌';
|
16
|
+
}
|
17
|
+
|
18
|
+
case 'success':
|
19
|
+
{
|
20
|
+
return '✔';
|
21
|
+
}
|
22
|
+
|
23
|
+
case 'running':
|
24
|
+
{
|
25
|
+
return '🟡';
|
26
|
+
}
|
27
|
+
|
28
|
+
case 'pending':
|
29
|
+
{
|
30
|
+
return '🕗';
|
31
|
+
}
|
32
|
+
|
33
|
+
default:
|
34
|
+
{
|
35
|
+
if (skip) return '⏸';
|
36
|
+
return '';
|
37
|
+
}
|
38
|
+
}
|
39
|
+
}
|
40
|
+
|
41
|
+
const isInternetExplorer = navigator.userAgent.includes('Trident/');
|
42
|
+
exports.isInternetExplorer = isInternetExplorer;
|