@allurereport/web-classic 3.8.2 → 3.10.0

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 (70) hide show
  1. package/allurerc-dev.mjs +10 -0
  2. package/dist/multi/app-0638edd2daa9730d5153.js +2 -0
  3. package/dist/multi/manifest.json +23 -23
  4. package/dist/multi/styles-1f77adc2ac439c7a4c4b.css +284 -0
  5. package/dist/single/app-099b8ba247b13f22ce56.js +2 -0
  6. package/dist/single/manifest.json +1 -1
  7. package/package.json +18 -14
  8. package/src/assets/scss/code.scss +6 -6
  9. package/src/assets/scss/index.scss +8 -8
  10. package/src/components/Behaviors/styles.scss +38 -33
  11. package/src/components/Categories/styles.scss +38 -33
  12. package/src/components/HeaderActions/styles.scss +1 -1
  13. package/src/components/Modal/index.tsx +3 -1
  14. package/src/components/Modal/styles.scss +2 -2
  15. package/src/components/Packages/styles.scss +38 -33
  16. package/src/components/ReportBody/styles.scss +1 -1
  17. package/src/components/TestResult/TestResultError/styles.scss +4 -4
  18. package/src/components/TestResult/TestResultLinks/styles.scss +1 -1
  19. package/src/components/TestResult/TestResultNavigation/index.tsx +1 -1
  20. package/src/components/TestResult/TestResultPrevStatuses/styles.scss +5 -5
  21. package/src/components/TestResult/TestResultSeverity/styles.scss +4 -4
  22. package/src/components/TestResult/TestResultStatus/styles.scss +2 -35
  23. package/src/components/TestResult/TestResultSteps/attachment.tsx +24 -2
  24. package/src/components/TestResult/TestResultSteps/attachmentVideo.tsx +3 -1
  25. package/src/components/TestResult/TestResultSteps/styles.scss +35 -17
  26. package/src/components/TestResult/TestResultSteps/testResultAttachmentInfo.tsx +1 -0
  27. package/src/components/TestResult/TestResultSteps/testResultStep.tsx +2 -2
  28. package/src/components/TestResult/TestResultTabs/styles.scss +1 -1
  29. package/src/components/Tree/TreeHeader.tsx +1 -1
  30. package/src/components/Tree/styles.scss +38 -33
  31. package/src/index.html +3 -3
  32. package/src/index.js +1 -0
  33. package/src/utils/attachments.ts +6 -0
  34. package/test/dummy.test.ts +9 -1
  35. package/test/utils/treeFilters.test.ts +9 -1
  36. package/types.d.ts +1 -0
  37. package/webpack.config.js +8 -5
  38. package/dist/multi/app-f80e40e5d4a6b2591c77.js +0 -2
  39. package/dist/multi/styles-782990bab862d8dfb55a.css +0 -284
  40. package/dist/single/app-d95b6198c4d471014aa1.js +0 -2
  41. package/src/assets/scss/day.scss +0 -51
  42. package/src/assets/scss/fonts.scss +0 -3
  43. package/src/assets/scss/night.scss +0 -61
  44. package/src/assets/scss/palette.scss +0 -393
  45. package/src/assets/scss/theme.scss +0 -326
  46. package/src/assets/scss/typography.scss +0 -218
  47. package/src/assets/scss/vars.scss +0 -8
  48. /package/dist/multi/{10.app-f80e40e5d4a6b2591c77.js → 10.app-0638edd2daa9730d5153.js} +0 -0
  49. /package/dist/multi/{222.app-f80e40e5d4a6b2591c77.js → 222.app-0638edd2daa9730d5153.js} +0 -0
  50. /package/dist/multi/{26.app-f80e40e5d4a6b2591c77.js → 26.app-0638edd2daa9730d5153.js} +0 -0
  51. /package/dist/multi/{302.app-f80e40e5d4a6b2591c77.js → 302.app-0638edd2daa9730d5153.js} +0 -0
  52. /package/dist/multi/{304.app-f80e40e5d4a6b2591c77.js → 304.app-0638edd2daa9730d5153.js} +0 -0
  53. /package/dist/multi/{333.app-f80e40e5d4a6b2591c77.js → 333.app-0638edd2daa9730d5153.js} +0 -0
  54. /package/dist/multi/{369.app-f80e40e5d4a6b2591c77.js → 369.app-0638edd2daa9730d5153.js} +0 -0
  55. /package/dist/multi/{389.app-f80e40e5d4a6b2591c77.js → 389.app-0638edd2daa9730d5153.js} +0 -0
  56. /package/dist/multi/{498.app-f80e40e5d4a6b2591c77.js → 498.app-0638edd2daa9730d5153.js} +0 -0
  57. /package/dist/multi/{60.app-f80e40e5d4a6b2591c77.js → 60.app-0638edd2daa9730d5153.js} +0 -0
  58. /package/dist/multi/{643.app-f80e40e5d4a6b2591c77.js → 643.app-0638edd2daa9730d5153.js} +0 -0
  59. /package/dist/multi/{671.app-f80e40e5d4a6b2591c77.js → 671.app-0638edd2daa9730d5153.js} +0 -0
  60. /package/dist/multi/{725.app-f80e40e5d4a6b2591c77.js → 725.app-0638edd2daa9730d5153.js} +0 -0
  61. /package/dist/multi/{770.app-f80e40e5d4a6b2591c77.js → 770.app-0638edd2daa9730d5153.js} +0 -0
  62. /package/dist/multi/{848.app-f80e40e5d4a6b2591c77.js → 848.app-0638edd2daa9730d5153.js} +0 -0
  63. /package/dist/multi/{853.app-f80e40e5d4a6b2591c77.js → 853.app-0638edd2daa9730d5153.js} +0 -0
  64. /package/dist/multi/{872.app-f80e40e5d4a6b2591c77.js → 872.app-0638edd2daa9730d5153.js} +0 -0
  65. /package/dist/multi/{895.app-f80e40e5d4a6b2591c77.js → 895.app-0638edd2daa9730d5153.js} +0 -0
  66. /package/dist/multi/{920.app-f80e40e5d4a6b2591c77.js → 920.app-0638edd2daa9730d5153.js} +0 -0
  67. /package/dist/multi/{979.app-f80e40e5d4a6b2591c77.js → 979.app-0638edd2daa9730d5153.js} +0 -0
  68. /package/dist/multi/{991.app-f80e40e5d4a6b2591c77.js → 991.app-0638edd2daa9730d5153.js} +0 -0
  69. /package/dist/multi/{app-f80e40e5d4a6b2591c77.js.LICENSE.txt → app-0638edd2daa9730d5153.js.LICENSE.txt} +0 -0
  70. /package/dist/single/{app-d95b6198c4d471014aa1.js.LICENSE.txt → app-099b8ba247b13f22ce56.js.LICENSE.txt} +0 -0
@@ -2,7 +2,7 @@
2
2
  position: relative;
3
3
 
4
4
  &:not(:first-child) {
5
- border-top: 1px solid var(--on-border-muted);
5
+ border-top: 1px solid var(--color-border-subtle);
6
6
  }
7
7
  }
8
8
 
@@ -19,7 +19,7 @@
19
19
  padding: 4px 8px 4px 6px;
20
20
 
21
21
  &:hover {
22
- background: var(--bg-control-flat-medium);
22
+ background: var(--color-control-bg-ghost-hover);
23
23
  }
24
24
  }
25
25
 
@@ -53,15 +53,15 @@
53
53
  position: relative;
54
54
 
55
55
  &:hover {
56
- background: var(--bg-control-flat-medium);
56
+ background: var(--color-control-bg-ghost-hover);
57
57
  }
58
58
 
59
59
  &:not(:first-child) {
60
- border-top: 1px solid var(--on-border-muted);
60
+ border-top: 1px solid var(--color-border-subtle);
61
61
  }
62
62
  }
63
63
  .tree-item-marked {
64
- background: var(--bg-base-secondary);
64
+ background: var(--color-bg-secondary);
65
65
  }
66
66
 
67
67
  .item-title {
@@ -71,7 +71,7 @@
71
71
  .item-time {
72
72
  flex: none;
73
73
  margin-left: auto;
74
- color: var(--on-text-hint);
74
+ color: var(--color-text-muted);
75
75
  }
76
76
 
77
77
  .test-count {
@@ -83,7 +83,7 @@
83
83
  display: block;
84
84
  padding-left: 24px;
85
85
  margin-bottom: 12px;
86
- border-top: 1px solid var(--on-border-muted);
86
+ border-top: 1px solid var(--color-border-subtle);
87
87
  }
88
88
 
89
89
  .tree-item-icon {
@@ -92,71 +92,76 @@
92
92
  }
93
93
 
94
94
  .status-passed {
95
- color: var(--bg-support-castor);
95
+ color: var(--color-status-passed-bg);
96
96
  }
97
97
 
98
98
  .status-failed {
99
- color: var(--bg-support-capella);
99
+ color: var(--color-status-failed-bg);
100
100
  }
101
101
 
102
102
  .status-broken {
103
- color: var(--bg-support-atlas);
103
+ color: var(--color-status-broken-bg);
104
104
  }
105
105
 
106
106
  .status-skipped {
107
- color: var(--bg-support-rau);
107
+ color: var(--color-status-skipped-bg);
108
108
  }
109
109
 
110
110
  .status-unknown {
111
- color: var(--bg-support-skat);
111
+ color: var(--color-status-unknown-bg);
112
112
  }
113
113
 
114
114
  .tree-header-bar {
115
115
  display: inline-flex;
116
+ align-items: center;
117
+ gap: var(--space-0-25);
116
118
  font-family: var(--font-family);
117
119
  max-width: 140px;
118
120
  min-width: 46px;
119
- border-radius: 4px;
120
- height: 12px;
121
- background: var(--on-text-hint);
121
+ height: var(--space-2);
122
+ background: transparent;
122
123
  margin-left: auto;
123
- font-size: 10px;
124
- font-weight: var(--font-weight-extra-bold);
125
- line-height: 12px;
126
- overflow: hidden;
124
+ font-size: var(--font-size-xs);
125
+ font-weight: var(--font-weight-bold);
126
+ line-height: var(--line-height-s);
127
+ overflow: visible;
127
128
  }
128
129
 
129
130
  .tree-header-bar-item {
130
131
  display: flex;
131
- min-width: 16px;
132
+ align-items: center;
132
133
  justify-content: center;
134
+ box-sizing: border-box;
135
+ min-width: var(--space-2);
136
+ height: var(--space-2);
137
+ border-radius: var(--radius-pill);
133
138
  text-align: center;
134
- padding: 0 6px;
139
+ padding: 0 var(--space-0-75);
135
140
  flex-grow: 1;
136
141
 
137
142
  &.passed {
138
- background-color: var(--bg-support-castor);
139
- color: var(--constant-on-text-primary);
143
+ background-color: var(--color-status-passed-bg);
144
+ color: var(--color-status-passed-on-bg);
140
145
  }
141
146
 
142
147
  &.failed {
143
- background-color: var(--bg-support-capella);
144
- color: var(--constant-on-text-primary);
148
+ background-color: var(--color-status-failed-bg);
149
+ color: var(--color-status-failed-on-bg);
145
150
  }
146
151
 
147
152
  &.broken {
148
- background-color: var(--bg-support-atlas);
149
- color: var(--constant-on-text-primary);
153
+ background-color: var(--color-status-broken-bg);
154
+ color: var(--color-status-broken-on-bg);
150
155
  }
151
156
 
152
157
  &.skipped {
153
- background-color: var(--bg-support-rau);
154
- color: var(--constant-on-text-primary);
158
+ background-color: var(--color-status-skipped-bg);
159
+ color: var(--color-status-skipped-on-bg);
155
160
  }
156
161
 
157
162
  &.unknown {
158
- background-color: var(--bg-support-skat);
159
- color: var(--constant-on-text-primary);
163
+ background-color: var(--color-status-unknown-bg);
164
+ color: var(--color-status-unknown-on-bg);
160
165
  }
161
166
  }
162
167
 
@@ -166,7 +171,7 @@
166
171
  }
167
172
 
168
173
  .tree-empty-results-title {
169
- color: var(--on-text-secondary);
174
+ color: var(--color-text-secondary);
170
175
  }
171
176
 
172
177
  .tree-empty-results-clear-button {
@@ -175,7 +180,7 @@
175
180
 
176
181
  .order {
177
182
  user-select: none;
178
- color: var(--on-text-hint);
183
+ color: var(--color-text-muted);
179
184
  min-width: 16px;
180
185
  text-align: center;
181
186
  box-sizing: content-box;
package/src/index.html CHANGED
@@ -12,11 +12,11 @@
12
12
  <script>
13
13
  window.allureReportOptions = {
14
14
  reportName: "Allure Classic Report (Dev)",
15
- logo: "/data/logo.jpg",
15
+ logo: "",
16
16
  theme: "light",
17
- reportLanguage: "ru",
17
+ reportLanguage: "en",
18
18
  createdAt: 1731513697651,
19
- groupBy: "suite",
19
+ groupBy: ["epic", "feature", "story"],
20
20
  };
21
21
  </script>
22
22
  </head>
package/src/index.js CHANGED
@@ -16,6 +16,7 @@ import "./favicon.ico";
16
16
  import "./pluginApi.js";
17
17
  import "./plugins/default/index.js";
18
18
  import "./plugins/screen-diff/index.js";
19
+
19
20
  import "./plugins/screen-diff/styles.css";
20
21
  import "./plugins/tab-behaviors/index.js";
21
22
  import "./plugins/tab-category/index.js";
@@ -29,6 +29,7 @@ export const fetchAttachment = async (id: string, ext: string, contentType: stri
29
29
  case "uri":
30
30
  case "code":
31
31
  case "html":
32
+ case "markdown":
32
33
  case "table":
33
34
  case "text": {
34
35
  const text = await response.text();
@@ -105,6 +106,11 @@ export const attachmentType = (type: string) => {
105
106
  type: "text",
106
107
  icon: "txt",
107
108
  };
109
+ case "text/markdown":
110
+ return {
111
+ type: "markdown",
112
+ icon: "file",
113
+ };
108
114
  case "text/html":
109
115
  return {
110
116
  type: "html",
@@ -1,4 +1,12 @@
1
- import { describe, expect, it } from "vitest";
1
+ import { epic, feature, label, story } from "allure-js-commons";
2
+ import { beforeEach, describe, expect, it } from "vitest";
3
+
4
+ beforeEach(async () => {
5
+ await epic("coverage");
6
+ await feature("plugin-classic");
7
+ await story("dummy");
8
+ await label("coverage", "plugin-classic");
9
+ });
2
10
 
3
11
  describe("dummy", () => {
4
12
  it("works", () => {
@@ -1,8 +1,16 @@
1
- import { describe, expect, it } from "vitest";
1
+ import { epic, feature, label, story } from "allure-js-commons";
2
+ import { beforeEach, describe, expect, it } from "vitest";
2
3
 
3
4
  import { createRecursiveTree, filterLeaves } from "../../src/utils/treeFilters.js";
4
5
  import type { ClassicTestResult } from "../../types.js";
5
6
 
7
+ beforeEach(async () => {
8
+ await epic("coverage");
9
+ await feature("filters");
10
+ await story("treeFilters");
11
+ await label("coverage", "filters");
12
+ });
13
+
6
14
  describe("utils > treeFilters", () => {
7
15
  describe("filterLeaves", () => {
8
16
  it("returns the leaves as is when no filter options are provided", () => {
package/types.d.ts CHANGED
@@ -51,6 +51,7 @@ export type ClassicTestResult = Omit<
51
51
  | "preconditionHtml"
52
52
  | "steps"
53
53
  > & {
54
+ isRetry: boolean;
54
55
  setup: ClassicFixtureResult[];
55
56
  teardown: ClassicFixtureResult[];
56
57
  steps: ClassicTestStepResult[];
package/webpack.config.js CHANGED
@@ -1,11 +1,14 @@
1
- import HtmlWebpackPlugin from "html-webpack-plugin";
2
- import MiniCssExtractPlugin from "mini-css-extract-plugin";
1
+ import { createRequire } from "node:module";
3
2
  import { dirname, join } from "node:path";
4
3
  import { env } from "node:process";
5
4
  import { fileURLToPath } from "node:url";
6
- import SpriteLoaderPlugin from "svg-sprite-loader/plugin.js";
7
- import webpack from "webpack";
8
- import { WebpackManifestPlugin } from "webpack-manifest-plugin";
5
+
6
+ const require = createRequire(import.meta.url);
7
+ const HtmlWebpackPlugin = require("html-webpack-plugin");
8
+ const MiniCssExtractPlugin = require("mini-css-extract-plugin");
9
+ const SpriteLoaderPlugin = require("svg-sprite-loader/plugin");
10
+ const webpack = require("webpack");
11
+ const { WebpackManifestPlugin } = require("webpack-manifest-plugin");
9
12
 
10
13
  const { SINGLE_FILE_MODE } = env;
11
14
  const baseDir = dirname(fileURLToPath(import.meta.url));