mirror of
https://github.com/Kong/insomnia
synced 2024-11-08 23:00:30 +00:00
5b7f45e910
* share design documents and tests with insomnia sync * share collection and documents with insomnia/git sync * checkpoint * redirect when cloning (pulling) a new remote project * backend workspace card * redirect logic * local changes styles * loading indicator * fix sync button styles * use interval to refetch git * open the repo modal first before switching to git sync * use gitRepositoryId from metadata * fix sync option update * cleanup fetcher check * fixes * cleanup pull-push * undo logo change * clean git-vcs * use cloud icon for insomnia sync * cleanup card * more cleanup * better return type for fetchfetcher * update git tests * fix tests * fix some prerelease tests * fix cloning without an api spec * fix some more tests that expect a file to exist * fix lint error
42 lines
1.9 KiB
TypeScript
42 lines
1.9 KiB
TypeScript
import { test } from '../../playwright/test';
|
|
|
|
test('Sign in with Gitlab', async ({ app, page }) => {
|
|
await page.getByRole('button', { name: 'New Document' }).click();
|
|
await page.getByRole('dialog').getByRole('button', { name: 'Create' }).click();
|
|
await page.getByRole('button', { name: 'Git Sync' }).click();
|
|
await page.getByRole('button', { name: 'Setup Git Sync' }).click();
|
|
await page.getByRole('tab', { name: 'GitLab' }).click();
|
|
|
|
const fakeGitLabOAuthWebFlow = app.evaluate(electron => {
|
|
return new Promise<{ redirectUrl: string }>(resolve => {
|
|
const webContents = electron.BrowserWindow.getAllWindows()[0].webContents;
|
|
// Remove all navigation listeners so that only the one we inject will run
|
|
webContents.removeAllListeners('will-navigate');
|
|
webContents.on('will-navigate', (event: Event, url: string) => {
|
|
event.preventDefault();
|
|
const parsedUrl = new URL(url);
|
|
// We use the same state parameter that the app created to assert that we prevent CSRF
|
|
const stateSearchParam = parsedUrl.searchParams.get('state') || '';
|
|
const redirectUrl = `insomnia://oauth/gitlab/authenticate?code=12345&state=${stateSearchParam}`;
|
|
resolve({ redirectUrl });
|
|
});
|
|
});
|
|
});
|
|
|
|
const [{ redirectUrl }] = await Promise.all([
|
|
fakeGitLabOAuthWebFlow,
|
|
page.getByText('Authenticate with GitLab').click({
|
|
// When playwright clicks a link it waits for navigation to finish.
|
|
// In our case we are stubbing the navigation and we don't want to wait for it.
|
|
noWaitAfter: true,
|
|
}),
|
|
]);
|
|
|
|
await page.locator('input[name="link"]').click();
|
|
await page.locator('input[name="link"]').fill(redirectUrl);
|
|
await page.getByRole('button', { name: 'Add' }).click();
|
|
|
|
test.expect(await page.locator('text="Mark Kim"')).toBeTruthy();
|
|
test.expect(await page.locator('button[name="sign-out"]')).toBeTruthy();
|
|
});
|