-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
mrc-5967 update e2e tests #229
Changes from 2 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -33,9 +33,9 @@ beta <- user(4) | |
sigma <- user(2) | ||
`; | ||
|
||
const editorGlyphs: any = { | ||
error: "fa-solid fa-circle-xmark", | ||
warning: "fa-solid fa-triangle-exclamation" | ||
const editorGlyphs: Record<EditorStates, string> = { | ||
error: "fa-circle-xmark", | ||
warning: "fa-triangle-exclamation" | ||
}; | ||
|
||
enum EditorStates { | ||
|
@@ -47,36 +47,40 @@ test.beforeEach(async ({ page }) => { | |
await page.goto("/apps/day1"); | ||
}); | ||
|
||
const expectMonacoDecoration = async (state: EditorStates, line: number, numOfLines: number, page: any) => { | ||
const expectMonacoDecoration = async (state: EditorStates, line: number, numOfLines: number, page: Page) => { | ||
for (let i = 0; i < numOfLines; i += 1) { | ||
const lineElement = await page.locator(`.view-overlays div:nth-child(${i + 1}) >> div`); | ||
const glyphElement = await page.locator(`.margin-view-overlays div:nth-child(${i + 1}) >> div`); | ||
if (i === line - 1) { | ||
expect(lineElement).toHaveClass(`cdr editor-${state}-background`); | ||
expect(glyphElement.nth(0)).toHaveClass(`cgmr codicon ${editorGlyphs[state]} ${state}-glyph-style ms-1`); | ||
expect(glyphElement.nth(1)).toHaveClass("line-numbers lh-odd"); | ||
await expect(lineElement).toHaveClass(`cdr editor-${state}-background`); | ||
} else if (i === numOfLines - 1) { | ||
expect(lineElement).toHaveClass("current-line"); | ||
expect(glyphElement.nth(0)).toHaveClass("current-line current-line-margin-both"); | ||
expect(glyphElement.nth(1)).toHaveClass(/\bactive-line-number\b/); | ||
expect(glyphElement.nth(1)).toHaveClass(/\bline-numbers\b/); | ||
expect(glyphElement.nth(1)).toHaveClass(/\blh-odd\b/); | ||
await expect(lineElement).toHaveClass("current-line"); | ||
} else { | ||
expect(lineElement).toHaveCount(0); | ||
expect(glyphElement).toHaveClass("line-numbers lh-odd"); | ||
await expect(lineElement).toHaveCount(0); | ||
} | ||
} | ||
|
||
const lineHeight = await page.locator(".margin-view-overlays").evaluate(el => { | ||
return window.getComputedStyle(el).getPropertyValue("line-height"); | ||
}); | ||
const glyphTop = await page.locator(`.${editorGlyphs[state]}`).evaluate(el => { | ||
return window.getComputedStyle(el).getPropertyValue("top"); | ||
}); | ||
expect(glyphTop).toBe(`${(line - 1) * parseInt(lineHeight)}px`); | ||
}; | ||
|
||
const expectMonacoHover = async (type: "glyph" | "content", line: number, message: string, page: any) => { | ||
const expectMonacoHover = async (type: "glyph" | "content", line: number, message: string, page: Page) => { | ||
const isGlyph = type === "glyph"; | ||
const hoverElem = `.${isGlyph ? "margin-" : ""}view-overlays div:nth-child(${line}) >> div`; | ||
const tooltipElem = `${isGlyph ? ".overlayWidgets" : ".overflowingContentWidgets"} .hover-contents div p`; | ||
const hoverElem = type === "content" ? | ||
`.view-overlays div:nth-child(${line}) >> div` : | ||
".glyph-margin-widgets .fa-solid"; | ||
// const hoverElem = `.${isGlyph ? "margin-" : ""}view-overlays div:nth-child(${line}) >> div`; | ||
// const tooltipElem = `${isGlyph ? ".overlayWidgets" : ".overflowingContentWidgets"} .hover-contents div p`; | ||
await page.hover(hoverElem, { force: true }); | ||
const tooltip = await page.locator(tooltipElem); | ||
await tooltip.waitFor({ timeout: 1000 }); | ||
await expect(tooltip).toHaveText(message); | ||
await expect(tooltip).toHaveCSS("visibility", "visible"); | ||
// const tooltip = await page.locator(tooltipElem); | ||
// await tooltip.waitFor({ timeout: 2000 }); | ||
// await expect(tooltip).toHaveText(message); | ||
// await expect(tooltip).toHaveCSS("visibility", "visible"); | ||
Comment on lines
+82
to
+88
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ignore the commented out code and the block below, i remove them in the next PR, i accidentally pushed the cleaning out commented code commit to the next pr |
||
await expect(await page.getByText(message)).toBeVisible() | ||
}; | ||
|
||
test.describe("Code Tab tests", () => { | ||
|
@@ -128,9 +132,9 @@ test.describe("Code Tab tests", () => { | |
test("code loading on input renders as expected", async ({ page }) => { | ||
await page.press(".monaco-editor textarea", "Control+A"); | ||
await page.press(".monaco-editor textarea", "Delete"); | ||
page.fill(".monaco-editor textarea", "blah"); | ||
expect(page.locator("#code-status")).toHaveClass("mt-2 code-validating-text"); | ||
expect(page.locator("#code-status").locator("i")).toHaveClass( | ||
await page.fill(".monaco-editor textarea", "blah"); | ||
await expect(page.locator("#code-status")).toHaveClass("mt-2 code-validating-text"); | ||
await expect(page.locator("#code-status").locator("i")).toHaveClass( | ||
"vue-feather vue-feather--check inline-icon me-1 code-validating-icon" | ||
); | ||
}); | ||
|
@@ -355,12 +359,12 @@ test.describe("Code Tab tests", () => { | |
|
||
test("can display help dialog", async ({ page }) => { | ||
await page.click("div.code-tab i.generic-help-icon"); | ||
expect((await page.innerText(".draggable-dialog .dragtarget")).trim()).toBe("Write odin code"); | ||
expect(await page.innerText(".draggable-dialog .draggable-content")).toContain("Write code in this editor"); | ||
await expect((await page.innerText(".draggable-dialog .dragtarget")).trim()).toBe("Write odin code"); | ||
await expect(await page.innerText(".draggable-dialog .draggable-content")).toContain("Write code in this editor"); | ||
|
||
// close dialog | ||
await page.click("i.vue-feather--x"); | ||
expect(await page.locator(".draggable-dialog")).not.toBeVisible(); | ||
await expect(await page.locator(".draggable-dialog")).not.toBeVisible(); | ||
}); | ||
|
||
test("can see error after changing tabs and coming back", async ({ page }) => { | ||
|
@@ -378,7 +382,7 @@ test.describe("Code Tab tests", () => { | |
await page.click(".nav-tabs a:has-text('Options')"); | ||
await page.click(".nav-tabs a:has-text('Code')"); | ||
const lineElement = await page.locator(`.view-overlays div:nth-child(${2}) >> div`); | ||
expect(lineElement).toHaveClass("cdr editor-error-background"); | ||
await expect(lineElement).toHaveClass("cdr editor-error-background"); | ||
}); | ||
|
||
test("can see warning after changing tabs and coming back", async ({ page }) => { | ||
|
@@ -396,7 +400,7 @@ test.describe("Code Tab tests", () => { | |
await page.click(".nav-tabs a:has-text('Options')"); | ||
await page.click(".nav-tabs a:has-text('Code')"); | ||
const lineElement = await page.locator(`.view-overlays div:nth-child(${3}) >> div`); | ||
expect(lineElement).toHaveClass("cdr editor-warning-background"); | ||
await expect(lineElement).toHaveClass("cdr editor-warning-background"); | ||
}); | ||
|
||
test("can change graph setting for log scale y axis from code tab", async ({ page }) => { | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -206,7 +206,7 @@ test.describe("Options Tab tests", () => { | |
test("can change graph setting for log scale y axis", async ({ page }) => { | ||
await page.locator(".log-scale-y-axis input").click(); | ||
// should update y axis tick | ||
const tickSelector = ":nth-match(.plotly .ytick text, 2)"; | ||
const tickSelector = ":nth-match(.ytick text, 2)"; | ||
await expect(await page.innerHTML(tickSelector)).toBe("10n"); | ||
// change back to linear | ||
await page.locator(".log-scale-y-axis input").click(); | ||
|
@@ -216,7 +216,7 @@ test.describe("Options Tab tests", () => { | |
test("can change graph setting for lock axes", async ({ page }) => { | ||
await page.locator(".lock-y-axis input").click(); | ||
|
||
const tickSelector = ":nth-match(.plotly .ytick text, 6)"; | ||
const tickSelector = ":nth-match(.ytick text, 6)"; | ||
await expect(await page.innerHTML(tickSelector)).toBe("1M"); | ||
|
||
await page.locator(":nth-match(.parameter-input, 3)").fill("1000000000"); | ||
|
@@ -234,7 +234,7 @@ test.describe("Options Tab tests", () => { | |
test("overrides axes lock if log scale toggle changes", async ({ page }) => { | ||
await page.locator(".lock-y-axis input").click(); | ||
|
||
const tickSelector = ":nth-match(.plotly .ytick text, 2)"; | ||
const tickSelector = ":nth-match(.ytick text, 2)"; | ||
await expect(await page.innerHTML(tickSelector)).toBe("0.2M"); | ||
|
||
await page.locator(".log-scale-y-axis input").click(); | ||
|
@@ -412,13 +412,13 @@ test.describe("Options Tab tests", () => { | |
await sigmaParam.fill("3"); | ||
|
||
const sigmaSavedParamTile = page.getByText("sigma: 2"); | ||
expect(sigmaSavedParamTile).toBeVisible(); | ||
expect(page.getByText("beta: 4")).not.toBeVisible(); | ||
await expect(sigmaSavedParamTile).toBeVisible(); | ||
await expect(page.getByText("beta: 4")).not.toBeVisible(); | ||
|
||
await page.getByLabel("Show unchanged parameters").check(); | ||
|
||
expect(sigmaSavedParamTile).toBeVisible(); | ||
expect(page.getByText("beta: 4")).toBeVisible(); | ||
await expect(sigmaSavedParamTile).toBeVisible(); | ||
await expect(page.getByText("beta: 4")).toBeVisible(); | ||
}); | ||
|
||
test("error tooltip and doesn't change name if same name exists", async ({ page }) => { | ||
|
@@ -434,20 +434,23 @@ test.describe("Options Tab tests", () => { | |
await editDisplayName(2, page); | ||
await inputDisplayName(2, page, "random name 1"); | ||
await saveDisplayName(1, page); | ||
await expect((await page.innerText(":nth-match(.tooltip-inner, 2)")).trim()).toBe("Name already exists"); | ||
await expect(await page.isVisible(":nth-match(.param-name-input, 2)")).toBe(true); | ||
await expect(await page.getByText("Name already exists")).toBeVisible(); | ||
}); | ||
|
||
test("error tooltip and doesn't change name if Set [number] format used", async ({ page }) => { | ||
await createParameterSet(page); | ||
await editDisplayName(1, page); | ||
await inputDisplayName(1, page, "Set 10"); | ||
await saveDisplayName(1, page); | ||
await expect((await page.innerText(":nth-match(.tooltip-inner, 2)")).trim()).toBe( | ||
await expect(await page.getByText( | ||
"Set 10 (or any Set [number] combination) is reserved for default set names. " + | ||
"Please choose another set name or name this set back to its original name of 'Set 1'" | ||
); | ||
await expect(await page.isVisible(".param-name-input")).toBe(true); | ||
"Please choose another set name or name this set back to its original name of 'Set 1'" | ||
)).toBeVisible(); | ||
// await expect((await page.innerText(":nth-match(.tooltip-inner, 2)")).trim()).toBe( | ||
// "Set 10 (or any Set [number] combination) is reserved for default set names. " + | ||
// "Please choose another set name or name this set back to its original name of 'Set 1'" | ||
// ); | ||
// await expect(await page.isVisible(".param-name-input")).toBe(true); | ||
Comment on lines
+449
to
+453
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This can be removed now? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yep removed in the linting PR (next one) |
||
}); | ||
|
||
const fillInAdvancedInputs = async (type: string, advancedSetting: any, index: number) => { | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -57,6 +57,10 @@ test.describe("Sessions tests", () => { | |
return chromium.launchPersistentContext(userDataDir); | ||
}; | ||
|
||
test.use({ | ||
permissions: ["clipboard-read", "clipboard-write"] | ||
}) | ||
|
||
Comment on lines
+60
to
+63
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Does it? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yep it does! we have copy to clipboard buttons when we copy the code or link for a session and we check those like line 134 in this file |
||
test("can use Sessions page", async () => { | ||
const browser = await usePersistentContext(); | ||
const page = await browser.newPage(); | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I feel like this method could use some comments because I'm honestly quite confused about what's being checked for here! In the loop we're checking that there's only current-line/background styling for
numOfLines
th line and its predecessor? And then the last part is checking that the glyph is on the specified line (by top)..?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yep will add some comments but yh the for loop checks for the background colour of the line so the highlighting and this part is checking if the glyph is vertically aligned with the correct line number
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done