mirror of
https://github.com/zulip/zulip.git
synced 2025-11-04 22:13:26 +00:00
puppeteer: Add settings test for realm-playgrounds.
This commit is contained in:
committed by
Tim Abbott
parent
474d647f3b
commit
db2ad6bada
84
frontend_tests/puppeteer_tests/realm-playground.ts
Normal file
84
frontend_tests/puppeteer_tests/realm-playground.ts
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
import {strict as assert} from "assert";
|
||||||
|
|
||||||
|
import type {Page} from "puppeteer";
|
||||||
|
|
||||||
|
import common from "../puppeteer_lib/common";
|
||||||
|
|
||||||
|
type Playground = {
|
||||||
|
name: string;
|
||||||
|
pygments_language: string;
|
||||||
|
url_prefix: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
async function _add_playground_and_return_status(page: Page, payload: Playground): Promise<string> {
|
||||||
|
await page.waitForSelector(".admin-playground-form", {visible: true});
|
||||||
|
// Let's first ensure that the success/failure status from an earlier step has disappeared.
|
||||||
|
const admin_playground_status_selector = "div#admin-playground-status";
|
||||||
|
await page.waitForSelector(admin_playground_status_selector, {hidden: true, timeout: 4000});
|
||||||
|
|
||||||
|
// Now we can fill and click the submit button.
|
||||||
|
await common.fill_form(page, "form.admin-playground-form", payload);
|
||||||
|
// Not sure why, but page.click() doesn't seem to always click the submit button.
|
||||||
|
// So we resort to using eval with the button ID instead.
|
||||||
|
await page.$eval("#submit_playground_button", (el) => (el as HTMLInputElement).click());
|
||||||
|
|
||||||
|
// We return the success/failure status message back to the caller.
|
||||||
|
await page.waitForSelector(admin_playground_status_selector, {visible: true});
|
||||||
|
const admin_playground_status = await common.get_text_from_selector(
|
||||||
|
page,
|
||||||
|
admin_playground_status_selector,
|
||||||
|
);
|
||||||
|
return admin_playground_status;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function test_successful_playground_creation(page: Page): Promise<void> {
|
||||||
|
const payload = {
|
||||||
|
pygments_language: "Python",
|
||||||
|
name: "Python3 playground",
|
||||||
|
url_prefix: "https://python.example.com",
|
||||||
|
};
|
||||||
|
const status = await _add_playground_and_return_status(page, payload);
|
||||||
|
assert.strictEqual(status, "Custom playground added!");
|
||||||
|
await page.waitForSelector(".playground_row", {visible: true});
|
||||||
|
assert.strictEqual(
|
||||||
|
await common.get_text_from_selector(
|
||||||
|
page,
|
||||||
|
".playground_row span.playground_pygments_language",
|
||||||
|
),
|
||||||
|
"Python",
|
||||||
|
);
|
||||||
|
assert.strictEqual(
|
||||||
|
await common.get_text_from_selector(page, ".playground_row span.playground_name"),
|
||||||
|
"Python3 playground",
|
||||||
|
);
|
||||||
|
assert.strictEqual(
|
||||||
|
await common.get_text_from_selector(page, ".playground_row span.playground_url_prefix"),
|
||||||
|
"https://python.example.com",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
async function test_invalid_playground_parameters(page: Page): Promise<void> {
|
||||||
|
const payload = {
|
||||||
|
pygments_language: "Python",
|
||||||
|
name: "Python3 playground",
|
||||||
|
url_prefix: "not_a_url",
|
||||||
|
};
|
||||||
|
let status = await _add_playground_and_return_status(page, payload);
|
||||||
|
assert.strictEqual(status, "Failed: url_prefix is not a URL");
|
||||||
|
|
||||||
|
payload.url_prefix = "https://python.example.com";
|
||||||
|
payload.pygments_language = "py!@%&";
|
||||||
|
status = await _add_playground_and_return_status(page, payload);
|
||||||
|
assert.strictEqual(status, "Failed: Invalid characters in pygments language");
|
||||||
|
}
|
||||||
|
|
||||||
|
async function playground_test(page: Page): Promise<void> {
|
||||||
|
await common.log_in(page);
|
||||||
|
await common.manage_organization(page);
|
||||||
|
await page.click("li[data-section='playground-settings']");
|
||||||
|
|
||||||
|
await test_successful_playground_creation(page);
|
||||||
|
await test_invalid_playground_parameters(page);
|
||||||
|
}
|
||||||
|
|
||||||
|
common.run_test(playground_test);
|
||||||
@@ -1,13 +1,13 @@
|
|||||||
{{#with playground}}
|
{{#with playground}}
|
||||||
<tr>
|
<tr class="playground_row">
|
||||||
<td>
|
<td>
|
||||||
<span>{{pygments_language}}</span>
|
<span class="playground_pygments_language">{{pygments_language}}</span>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<span>{{playground_name}}</span>
|
<span class="playground_name">{{playground_name}}</span>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<span>{{url_prefix}}</span>
|
<span class="playground_url_prefix">{{url_prefix}}</span>
|
||||||
</td>
|
</td>
|
||||||
{{#if ../can_modify}}
|
{{#if ../can_modify}}
|
||||||
<td class="no-select actions">
|
<td class="no-select actions">
|
||||||
|
|||||||
@@ -42,7 +42,7 @@
|
|||||||
<label for="playground_url_prefix" class="control-label"> {{t "URL prefix" }}</label>
|
<label for="playground_url_prefix" class="control-label"> {{t "URL prefix" }}</label>
|
||||||
<input type="text" id="playground_url_prefix" name="url_prefix" placeholder="https://replit.com/languages/python3/?code=" />
|
<input type="text" id="playground_url_prefix" name="url_prefix" placeholder="https://replit.com/languages/python3/?code=" />
|
||||||
</div>
|
</div>
|
||||||
<button type="submit" class="button rounded sea-green">
|
<button type="submit" id="submit_playground_button" class="button rounded sea-green">
|
||||||
{{t 'Add code playground' }}
|
{{t 'Add code playground' }}
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user