@grafana/plugin-e2e 0.0.0 → 0.0.1

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 (90) hide show
  1. package/README.md +1 -0
  2. package/dist/api.d.ts +41 -0
  3. package/dist/api.js +15 -0
  4. package/dist/e2e-selectors/index.d.ts +2 -0
  5. package/dist/e2e-selectors/index.js +20 -0
  6. package/dist/e2e-selectors/resolver.d.ts +3 -0
  7. package/dist/e2e-selectors/resolver.js +38 -0
  8. package/dist/e2e-selectors/resolver.test.d.ts +1 -0
  9. package/dist/e2e-selectors/resolver.test.js +39 -0
  10. package/dist/e2e-selectors/types.d.ts +691 -0
  11. package/dist/e2e-selectors/types.js +2 -0
  12. package/dist/e2e-selectors/versioned/apis.d.ts +29 -0
  13. package/dist/e2e-selectors/versioned/apis.js +35 -0
  14. package/dist/e2e-selectors/versioned/components.d.ts +419 -0
  15. package/dist/e2e-selectors/versioned/components.js +426 -0
  16. package/dist/e2e-selectors/versioned/constants.d.ts +1 -0
  17. package/dist/e2e-selectors/versioned/constants.js +4 -0
  18. package/dist/e2e-selectors/versioned/index.d.ts +2 -0
  19. package/dist/e2e-selectors/versioned/index.js +7 -0
  20. package/dist/e2e-selectors/versioned/pages.d.ts +334 -0
  21. package/dist/e2e-selectors/versioned/pages.js +345 -0
  22. package/dist/e2e-selectors/versioned/types.d.ts +8 -0
  23. package/dist/e2e-selectors/versioned/types.js +2 -0
  24. package/dist/fixtures/annotationEditPage.d.ts +7 -0
  25. package/dist/fixtures/annotationEditPage.js +62 -0
  26. package/dist/fixtures/commands/createDataSource.d.ts +8 -0
  27. package/dist/fixtures/commands/createDataSource.js +110 -0
  28. package/dist/fixtures/commands/createDataSourceConfigPage.d.ts +8 -0
  29. package/dist/fixtures/commands/createDataSourceConfigPage.js +82 -0
  30. package/dist/fixtures/commands/login.d.ts +6 -0
  31. package/dist/fixtures/commands/login.js +88 -0
  32. package/dist/fixtures/commands/readProvision.d.ts +7 -0
  33. package/dist/fixtures/commands/readProvision.js +67 -0
  34. package/dist/fixtures/explorePage.d.ts +7 -0
  35. package/dist/fixtures/explorePage.js +59 -0
  36. package/dist/fixtures/grafanaVersion.d.ts +6 -0
  37. package/dist/fixtures/grafanaVersion.js +63 -0
  38. package/dist/fixtures/index.d.ts +14 -0
  39. package/dist/fixtures/index.js +29 -0
  40. package/dist/fixtures/newDashboardPage.d.ts +7 -0
  41. package/dist/fixtures/newDashboardPage.js +59 -0
  42. package/dist/fixtures/panelEditPage.d.ts +7 -0
  43. package/dist/fixtures/panelEditPage.js +56 -0
  44. package/dist/fixtures/selectors.d.ts +7 -0
  45. package/dist/fixtures/selectors.js +62 -0
  46. package/dist/fixtures/types.d.ts +2 -0
  47. package/dist/fixtures/types.js +2 -0
  48. package/dist/fixtures/variableEditPage.d.ts +7 -0
  49. package/dist/fixtures/variableEditPage.js +62 -0
  50. package/dist/index.d.ts +3 -0
  51. package/dist/index.js +22 -0
  52. package/dist/matchers/index.d.ts +20 -0
  53. package/dist/matchers/index.js +13 -0
  54. package/dist/matchers/toBeOK.d.ts +7 -0
  55. package/dist/matchers/toBeOK.js +69 -0
  56. package/dist/matchers/toDisplayPreviews.d.ts +7 -0
  57. package/dist/matchers/toDisplayPreviews.js +70 -0
  58. package/dist/matchers/toHavePanelError.d.ts +9 -0
  59. package/dist/matchers/toHavePanelError.js +74 -0
  60. package/dist/matchers/utils.d.ts +1 -0
  61. package/dist/matchers/utils.js +5 -0
  62. package/dist/models/AnnotationEditPage.d.ts +8 -0
  63. package/dist/models/AnnotationEditPage.js +82 -0
  64. package/dist/models/AnnotationPage.d.ts +8 -0
  65. package/dist/models/AnnotationPage.js +123 -0
  66. package/dist/models/DashboardPage.d.ts +15 -0
  67. package/dist/models/DashboardPage.js +163 -0
  68. package/dist/models/DataSourceConfigPage.d.ts +10 -0
  69. package/dist/models/DataSourceConfigPage.js +135 -0
  70. package/dist/models/DataSourcePicker.d.ts +6 -0
  71. package/dist/models/DataSourcePicker.js +86 -0
  72. package/dist/models/ExplorePage.d.ts +12 -0
  73. package/dist/models/ExplorePage.js +130 -0
  74. package/dist/models/GrafanaPage.d.ts +11 -0
  75. package/dist/models/GrafanaPage.js +150 -0
  76. package/dist/models/PanelEditPage.d.ts +15 -0
  77. package/dist/models/PanelEditPage.js +165 -0
  78. package/dist/models/TimeRange.d.ts +6 -0
  79. package/dist/models/TimeRange.js +119 -0
  80. package/dist/models/VariableEditPage.d.ts +10 -0
  81. package/dist/models/VariableEditPage.js +109 -0
  82. package/dist/models/VariablePage.d.ts +8 -0
  83. package/dist/models/VariablePage.js +107 -0
  84. package/dist/models/index.d.ts +8 -0
  85. package/dist/models/index.js +19 -0
  86. package/dist/selectorEngine.d.ts +4 -0
  87. package/dist/selectorEngine.js +18 -0
  88. package/dist/types.d.ts +54 -0
  89. package/dist/types.js +2 -0
  90. package/package.json +4 -4
@@ -0,0 +1,130 @@
1
+ "use strict";
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
18
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
19
+ return new (P || (P = Promise))(function (resolve, reject) {
20
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
21
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
22
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
23
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
24
+ });
25
+ };
26
+ var __generator = (this && this.__generator) || function (thisArg, body) {
27
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
28
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
29
+ function verb(n) { return function (v) { return step([n, v]); }; }
30
+ function step(op) {
31
+ if (f) throw new TypeError("Generator is already executing.");
32
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
33
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
34
+ if (y = 0, t) op = [op[0] & 2, t.value];
35
+ switch (op[0]) {
36
+ case 0: case 1: t = op; break;
37
+ case 4: _.label++; return { value: op[1], done: false };
38
+ case 5: _.label++; y = op[1]; op = [0]; continue;
39
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
40
+ default:
41
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
42
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
43
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
44
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
45
+ if (t[2]) _.ops.pop();
46
+ _.trys.pop(); continue;
47
+ }
48
+ op = body.call(thisArg, _);
49
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
50
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
51
+ }
52
+ };
53
+ Object.defineProperty(exports, "__esModule", { value: true });
54
+ exports.ExplorePage = void 0;
55
+ var test_1 = require("@playwright/test");
56
+ var DataSourcePicker_1 = require("./DataSourcePicker");
57
+ var GrafanaPage_1 = require("./GrafanaPage");
58
+ var TimeRange_1 = require("./TimeRange");
59
+ var ExplorePage = (function (_super) {
60
+ __extends(ExplorePage, _super);
61
+ function ExplorePage(ctx) {
62
+ var _this = _super.call(this, ctx) || this;
63
+ _this.datasource = new DataSourcePicker_1.DataSourcePicker(ctx);
64
+ _this.timeRange = new TimeRange_1.TimeRange(ctx);
65
+ return _this;
66
+ }
67
+ ExplorePage.prototype.goto = function (options) {
68
+ return __awaiter(this, void 0, void 0, function () {
69
+ return __generator(this, function (_a) {
70
+ switch (_a.label) {
71
+ case 0: return [4, _super.prototype.navigate.call(this, this.ctx.selectors.pages.Explore.url, options)];
72
+ case 1:
73
+ _a.sent();
74
+ return [2];
75
+ }
76
+ });
77
+ });
78
+ };
79
+ ExplorePage.prototype.getQueryEditorRow = function (refId) {
80
+ return __awaiter(this, void 0, void 0, function () {
81
+ var locator;
82
+ return __generator(this, function (_a) {
83
+ switch (_a.label) {
84
+ case 0:
85
+ locator = this.getByTestIdOrAriaLabel(this.ctx.selectors.components.QueryEditorRows.rows).filter({
86
+ has: this.getByTestIdOrAriaLabel(this.ctx.selectors.components.QueryEditorRow.title(refId)),
87
+ });
88
+ return [4, (0, test_1.expect)(locator).toBeVisible()];
89
+ case 1:
90
+ _a.sent();
91
+ return [2, locator];
92
+ }
93
+ });
94
+ });
95
+ };
96
+ ExplorePage.prototype.runQuery = function (options) {
97
+ return __awaiter(this, void 0, void 0, function () {
98
+ var components, responsePromise, _1;
99
+ var _this = this;
100
+ return __generator(this, function (_a) {
101
+ switch (_a.label) {
102
+ case 0:
103
+ components = this.ctx.selectors.components;
104
+ responsePromise = this.ctx.page.waitForResponse(function (resp) { return resp.url().includes(_this.ctx.selectors.apis.DataSource.query); }, options);
105
+ _a.label = 1;
106
+ case 1:
107
+ _a.trys.push([1, 3, , 6]);
108
+ return [4, this.getByTestIdOrAriaLabel(components.RefreshPicker.runButtonV2).click({
109
+ timeout: 1000,
110
+ })];
111
+ case 2:
112
+ _a.sent();
113
+ return [3, 6];
114
+ case 3:
115
+ _1 = _a.sent();
116
+ return [4, this.getByTestIdOrAriaLabel(components.PageToolbar.item(components.PageToolbar.shotMoreItems)).click()];
117
+ case 4:
118
+ _a.sent();
119
+ return [4, this.getByTestIdOrAriaLabel(components.RefreshPicker.runButtonV2).last().click()];
120
+ case 5:
121
+ _a.sent();
122
+ return [3, 6];
123
+ case 6: return [2, responsePromise];
124
+ }
125
+ });
126
+ });
127
+ };
128
+ return ExplorePage;
129
+ }(GrafanaPage_1.GrafanaPage));
130
+ exports.ExplorePage = ExplorePage;
@@ -0,0 +1,11 @@
1
+ import { Locator, Request } from '@playwright/test';
2
+ import { NavigateOptions, PluginTestCtx } from '../types';
3
+ export declare abstract class GrafanaPage {
4
+ readonly ctx: PluginTestCtx;
5
+ constructor(ctx: PluginTestCtx);
6
+ protected navigate(url: string, options?: NavigateOptions): Promise<void>;
7
+ getByTestIdOrAriaLabel(selector: string, root?: Locator): Locator;
8
+ mockQueryDataResponse<T = any>(json: T, status?: number): Promise<void>;
9
+ mockResourceResponse<T = any>(path: string, json: T, status?: number): Promise<void>;
10
+ waitForQueryDataRequest(cb?: (request: Request) => boolean | Promise<boolean>): Promise<Request>;
11
+ }
@@ -0,0 +1,150 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
49
+ Object.defineProperty(exports, "__esModule", { value: true });
50
+ exports.GrafanaPage = void 0;
51
+ var GrafanaPage = (function () {
52
+ function GrafanaPage(ctx) {
53
+ this.ctx = ctx;
54
+ }
55
+ GrafanaPage.prototype.navigate = function (url, options) {
56
+ return __awaiter(this, void 0, void 0, function () {
57
+ return __generator(this, function (_a) {
58
+ switch (_a.label) {
59
+ case 0:
60
+ if (options === null || options === void 0 ? void 0 : options.queryParams) {
61
+ url += "?".concat(options.queryParams.toString());
62
+ }
63
+ return [4, this.ctx.page.goto(url, __assign({ waitUntil: 'networkidle' }, options))];
64
+ case 1:
65
+ _a.sent();
66
+ return [2];
67
+ }
68
+ });
69
+ });
70
+ };
71
+ GrafanaPage.prototype.getByTestIdOrAriaLabel = function (selector, root) {
72
+ if (selector.startsWith('data-testid')) {
73
+ return (root || this.ctx.page).getByTestId(selector);
74
+ }
75
+ return (root || this.ctx.page).locator("[aria-label=\"".concat(selector, "\"]"));
76
+ };
77
+ GrafanaPage.prototype.mockQueryDataResponse = function (json, status) {
78
+ if (status === void 0) { status = 200; }
79
+ return __awaiter(this, void 0, void 0, function () {
80
+ var _this = this;
81
+ return __generator(this, function (_a) {
82
+ switch (_a.label) {
83
+ case 0: return [4, this.ctx.page.route(this.ctx.selectors.apis.DataSource.queryPattern, function (route) { return __awaiter(_this, void 0, void 0, function () {
84
+ return __generator(this, function (_a) {
85
+ switch (_a.label) {
86
+ case 0: return [4, route.fulfill({ json: json, status: status })];
87
+ case 1:
88
+ _a.sent();
89
+ return [2];
90
+ }
91
+ });
92
+ }); })];
93
+ case 1:
94
+ _a.sent();
95
+ return [2];
96
+ }
97
+ });
98
+ });
99
+ };
100
+ GrafanaPage.prototype.mockResourceResponse = function (path, json, status) {
101
+ if (status === void 0) { status = 200; }
102
+ return __awaiter(this, void 0, void 0, function () {
103
+ var _this = this;
104
+ return __generator(this, function (_a) {
105
+ switch (_a.label) {
106
+ case 0: return [4, this.ctx.page.route("".concat(this.ctx.selectors.apis.DataSource.resourceUIDPattern, "/").concat(path), function (route) { return __awaiter(_this, void 0, void 0, function () {
107
+ return __generator(this, function (_a) {
108
+ switch (_a.label) {
109
+ case 0: return [4, route.fulfill({ json: json, status: status })];
110
+ case 1:
111
+ _a.sent();
112
+ return [2];
113
+ }
114
+ });
115
+ }); })];
116
+ case 1:
117
+ _a.sent();
118
+ return [4, this.ctx.page.route("".concat(this.ctx.selectors.apis.DataSource.resourcePattern, "/").concat(path), function (route) { return __awaiter(_this, void 0, void 0, function () {
119
+ return __generator(this, function (_a) {
120
+ switch (_a.label) {
121
+ case 0: return [4, route.fulfill({ json: json, status: status })];
122
+ case 1:
123
+ _a.sent();
124
+ return [2];
125
+ }
126
+ });
127
+ }); })];
128
+ case 2:
129
+ _a.sent();
130
+ return [2];
131
+ }
132
+ });
133
+ });
134
+ };
135
+ GrafanaPage.prototype.waitForQueryDataRequest = function (cb) {
136
+ return __awaiter(this, void 0, void 0, function () {
137
+ var _this = this;
138
+ return __generator(this, function (_a) {
139
+ return [2, this.ctx.page.waitForRequest(function (request) {
140
+ if (request.url().includes(_this.ctx.selectors.apis.DataSource.query) && request.method() === 'POST') {
141
+ return cb ? cb(request) : true;
142
+ }
143
+ return false;
144
+ })];
145
+ });
146
+ });
147
+ };
148
+ return GrafanaPage;
149
+ }());
150
+ exports.GrafanaPage = GrafanaPage;
@@ -0,0 +1,15 @@
1
+ import { Locator } from '@playwright/test';
2
+ import { PanelError, PluginTestCtx, RequestOptions, Visualization } from '../types';
3
+ import { DataSourcePicker } from './DataSourcePicker';
4
+ import { GrafanaPage } from './GrafanaPage';
5
+ import { TimeRange } from './TimeRange';
6
+ export declare class PanelEditPage extends GrafanaPage implements PanelError {
7
+ datasource: DataSourcePicker;
8
+ timeRange: TimeRange;
9
+ constructor(ctx: PluginTestCtx);
10
+ setVisualization(visualization: Visualization): Promise<void>;
11
+ apply(): Promise<void>;
12
+ getQueryEditorRow(refId: string): Promise<Locator>;
13
+ getPanelError(): Locator;
14
+ refreshPanel(options?: RequestOptions): Promise<import("playwright-core").Response>;
15
+ }
@@ -0,0 +1,165 @@
1
+ "use strict";
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
18
+ if (k2 === undefined) k2 = k;
19
+ var desc = Object.getOwnPropertyDescriptor(m, k);
20
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
21
+ desc = { enumerable: true, get: function() { return m[k]; } };
22
+ }
23
+ Object.defineProperty(o, k2, desc);
24
+ }) : (function(o, m, k, k2) {
25
+ if (k2 === undefined) k2 = k;
26
+ o[k2] = m[k];
27
+ }));
28
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
29
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
30
+ }) : function(o, v) {
31
+ o["default"] = v;
32
+ });
33
+ var __importStar = (this && this.__importStar) || function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
41
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
42
+ return new (P || (P = Promise))(function (resolve, reject) {
43
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
44
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
45
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
46
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
47
+ });
48
+ };
49
+ var __generator = (this && this.__generator) || function (thisArg, body) {
50
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
51
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
52
+ function verb(n) { return function (v) { return step([n, v]); }; }
53
+ function step(op) {
54
+ if (f) throw new TypeError("Generator is already executing.");
55
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
56
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
57
+ if (y = 0, t) op = [op[0] & 2, t.value];
58
+ switch (op[0]) {
59
+ case 0: case 1: t = op; break;
60
+ case 4: _.label++; return { value: op[1], done: false };
61
+ case 5: _.label++; y = op[1]; op = [0]; continue;
62
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
63
+ default:
64
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
65
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
66
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
67
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
68
+ if (t[2]) _.ops.pop();
69
+ _.trys.pop(); continue;
70
+ }
71
+ op = body.call(thisArg, _);
72
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
73
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
74
+ }
75
+ };
76
+ Object.defineProperty(exports, "__esModule", { value: true });
77
+ exports.PanelEditPage = void 0;
78
+ var test_1 = require("@playwright/test");
79
+ var semver = __importStar(require("semver"));
80
+ var DataSourcePicker_1 = require("./DataSourcePicker");
81
+ var GrafanaPage_1 = require("./GrafanaPage");
82
+ var TimeRange_1 = require("./TimeRange");
83
+ var ERROR_STATUS = 'error';
84
+ var PanelEditPage = (function (_super) {
85
+ __extends(PanelEditPage, _super);
86
+ function PanelEditPage(ctx) {
87
+ var _this = _super.call(this, ctx) || this;
88
+ _this.datasource = new DataSourcePicker_1.DataSourcePicker(ctx);
89
+ _this.timeRange = new TimeRange_1.TimeRange(ctx);
90
+ return _this;
91
+ }
92
+ PanelEditPage.prototype.setVisualization = function (visualization) {
93
+ return __awaiter(this, void 0, void 0, function () {
94
+ return __generator(this, function (_a) {
95
+ switch (_a.label) {
96
+ case 0: return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.PanelEditor.toggleVizPicker).click()];
97
+ case 1:
98
+ _a.sent();
99
+ return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.PluginVisualization.item(visualization)).click()];
100
+ case 2:
101
+ _a.sent();
102
+ return [4, (0, test_1.expect)(this.getByTestIdOrAriaLabel(this.ctx.selectors.components.PanelEditor.toggleVizPicker), "Could not set visualization to ".concat(visualization, ". Ensure the panel is installed.")).toHaveText(visualization)];
103
+ case 3:
104
+ _a.sent();
105
+ return [2];
106
+ }
107
+ });
108
+ });
109
+ };
110
+ PanelEditPage.prototype.apply = function () {
111
+ return __awaiter(this, void 0, void 0, function () {
112
+ return __generator(this, function (_a) {
113
+ switch (_a.label) {
114
+ case 0: return [4, this.ctx.page.getByTestId(this.ctx.selectors.components.PanelEditor.applyButton).click()];
115
+ case 1:
116
+ _a.sent();
117
+ return [2];
118
+ }
119
+ });
120
+ });
121
+ };
122
+ PanelEditPage.prototype.getQueryEditorRow = function (refId) {
123
+ return __awaiter(this, void 0, void 0, function () {
124
+ var locator;
125
+ return __generator(this, function (_a) {
126
+ switch (_a.label) {
127
+ case 0:
128
+ locator = this.getByTestIdOrAriaLabel(this.ctx.selectors.components.QueryEditorRows.rows).filter({
129
+ has: this.getByTestIdOrAriaLabel(this.ctx.selectors.components.QueryEditorRow.title(refId)),
130
+ });
131
+ return [4, (0, test_1.expect)(locator).toBeVisible()];
132
+ case 1:
133
+ _a.sent();
134
+ return [2, locator];
135
+ }
136
+ });
137
+ });
138
+ };
139
+ PanelEditPage.prototype.getPanelError = function () {
140
+ if (semver.lte(this.ctx.grafanaVersion, '9.4.3')) {
141
+ return this.getByTestIdOrAriaLabel(this.ctx.selectors.components.Panels.Panel.headerCornerInfo(ERROR_STATUS));
142
+ }
143
+ return this.getByTestIdOrAriaLabel(this.ctx.selectors.components.Panels.Panel.status(ERROR_STATUS));
144
+ };
145
+ PanelEditPage.prototype.refreshPanel = function (options) {
146
+ return __awaiter(this, void 0, void 0, function () {
147
+ var responsePromise;
148
+ var _this = this;
149
+ return __generator(this, function (_a) {
150
+ switch (_a.label) {
151
+ case 0:
152
+ responsePromise = this.ctx.page.waitForResponse(function (resp) { return resp.url().includes(_this.ctx.selectors.apis.DataSource.query); }, options);
153
+ return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.PanelEditor.General.content)
154
+ .locator("selector=".concat(this.ctx.selectors.components.RefreshPicker.runButtonV2))
155
+ .click()];
156
+ case 1:
157
+ _a.sent();
158
+ return [2, responsePromise];
159
+ }
160
+ });
161
+ });
162
+ };
163
+ return PanelEditPage;
164
+ }(GrafanaPage_1.GrafanaPage));
165
+ exports.PanelEditPage = PanelEditPage;
@@ -0,0 +1,6 @@
1
+ import { PluginTestCtx, TimeRangeArgs } from '../types';
2
+ import { GrafanaPage } from './GrafanaPage';
3
+ export declare class TimeRange extends GrafanaPage {
4
+ constructor(ctx: PluginTestCtx);
5
+ set({ from, to, zone }: TimeRangeArgs): Promise<void>;
6
+ }
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
18
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
19
+ return new (P || (P = Promise))(function (resolve, reject) {
20
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
21
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
22
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
23
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
24
+ });
25
+ };
26
+ var __generator = (this && this.__generator) || function (thisArg, body) {
27
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
28
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
29
+ function verb(n) { return function (v) { return step([n, v]); }; }
30
+ function step(op) {
31
+ if (f) throw new TypeError("Generator is already executing.");
32
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
33
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
34
+ if (y = 0, t) op = [op[0] & 2, t.value];
35
+ switch (op[0]) {
36
+ case 0: case 1: t = op; break;
37
+ case 4: _.label++; return { value: op[1], done: false };
38
+ case 5: _.label++; y = op[1]; op = [0]; continue;
39
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
40
+ default:
41
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
42
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
43
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
44
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
45
+ if (t[2]) _.ops.pop();
46
+ _.trys.pop(); continue;
47
+ }
48
+ op = body.call(thisArg, _);
49
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
50
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
51
+ }
52
+ };
53
+ Object.defineProperty(exports, "__esModule", { value: true });
54
+ exports.TimeRange = void 0;
55
+ var GrafanaPage_1 = require("./GrafanaPage");
56
+ var TimeRange = (function (_super) {
57
+ __extends(TimeRange, _super);
58
+ function TimeRange(ctx) {
59
+ return _super.call(this, ctx) || this;
60
+ }
61
+ TimeRange.prototype.set = function (_a) {
62
+ var from = _a.from, to = _a.to, zone = _a.zone;
63
+ return __awaiter(this, void 0, void 0, function () {
64
+ var e_1, fromField, toField;
65
+ return __generator(this, function (_b) {
66
+ switch (_b.label) {
67
+ case 0:
68
+ _b.trys.push([0, 2, , 4]);
69
+ return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.TimePicker.openButton).click()];
70
+ case 1:
71
+ _b.sent();
72
+ return [3, 4];
73
+ case 2:
74
+ e_1 = _b.sent();
75
+ return [4, this.ctx.page.locator('[aria-controls="TimePickerContent"]').last().click()];
76
+ case 3:
77
+ _b.sent();
78
+ return [3, 4];
79
+ case 4:
80
+ if (!zone) return [3, 7];
81
+ return [4, this.ctx.page.getByRole('button', { name: 'Change time settings' }).click()];
82
+ case 5:
83
+ _b.sent();
84
+ return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.TimeZonePicker.containerV2).fill(zone)];
85
+ case 6:
86
+ _b.sent();
87
+ _b.label = 7;
88
+ case 7: return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.TimePicker.absoluteTimeRangeTitle).click()];
89
+ case 8:
90
+ _b.sent();
91
+ return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.TimePicker.fromField)];
92
+ case 9:
93
+ fromField = _b.sent();
94
+ return [4, fromField.clear()];
95
+ case 10:
96
+ _b.sent();
97
+ return [4, fromField.fill(from)];
98
+ case 11:
99
+ _b.sent();
100
+ return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.TimePicker.toField)];
101
+ case 12:
102
+ toField = _b.sent();
103
+ return [4, toField.clear()];
104
+ case 13:
105
+ _b.sent();
106
+ return [4, toField.fill(to)];
107
+ case 14:
108
+ _b.sent();
109
+ return [4, this.getByTestIdOrAriaLabel(this.ctx.selectors.components.TimePicker.applyTimeRange).click()];
110
+ case 15:
111
+ _b.sent();
112
+ return [2];
113
+ }
114
+ });
115
+ });
116
+ };
117
+ return TimeRange;
118
+ }(GrafanaPage_1.GrafanaPage));
119
+ exports.TimeRange = TimeRange;
@@ -0,0 +1,10 @@
1
+ import { PluginTestCtx } from '../types';
2
+ import { DataSourcePicker } from './DataSourcePicker';
3
+ import { GrafanaPage } from './GrafanaPage';
4
+ export type VariableType = 'Query' | 'Constant' | 'Custom';
5
+ export declare class VariableEditPage extends GrafanaPage {
6
+ datasource: DataSourcePicker;
7
+ constructor(ctx: PluginTestCtx);
8
+ setVariableType(type: VariableType): Promise<void>;
9
+ runQuery(): Promise<void>;
10
+ }