insomnia/packages/insomnia-smoke-test/tests/smoke/git-sync.test.ts
James Gatz a6dabb2e15
Insomnia Sync improvements (#6738)
* almost there

* pending ui in sync dropdown

* branches pending ui

* fix snapshot staging issue

* staging modal fixes

* error handling on sync dropdown

* remove unused path

* switch to git repo button

* branch modal ui update

* change get method color

* staging modal ui

* onclose

* update export data modal

* fix websocket color

* remove export all button from scratchpad

* dropdown sections

* fetch remote branch properly

* test issue

* restore changes now works properly

* cleanup

* cleanup vcs usage

* cleanup sync items from workspace

* cleanup vcs from modals

* remove fragment

* turn vcs to instance to avoid module import side-effects

* fix e2e tests

* poll sync updates every minute

* change to named export

* Add some docs about data fetching in the app (sse,polling,fetch)

* improve revert changes copy
2023-11-06 15:24:51 +01:00

61 lines
2.8 KiB
TypeScript

import { test } from '../../playwright/test';
test('Clone from github', async ({ page }) => {
await page.getByLabel('Clone git repository').click();
await page.getByRole('tab', { name: ' Git' }).click();
await page.getByPlaceholder('https://github.com/org/repo.git').fill('https://github.com/gatzjames/insomnia-git-example.git');
await page.getByPlaceholder('Name').fill('J');
await page.getByPlaceholder('Email').fill('J');
await page.getByPlaceholder('MyUser').fill('J');
await page.getByPlaceholder('88e7ee63b254e4b0bf047559eafe86ba9dd49507').fill('J');
await page.getByTestId('git-repository-settings-modal__sync-btn').click();
await page.getByLabel('Toggle preview').click();
});
test('Sign in with GitHub', async ({ app, page }) => {
await page.getByRole('button', { name: 'New Document' }).click();
await page.getByRole('dialog').getByRole('button', { name: 'Create' }).click();
await page.getByLabel('Insomnia Sync').click();
await page.getByRole('menuitemradio', { name: 'Switch to Git Repository' }).click();
await page.getByRole('tab', { name: 'Github' }).click();
// Prevent the app from opening the browser to the authorization page
// and return the url that would be created by following the GitHub OAuth flow.
// https://docs.github.com/en/developers/apps/building-oauth-apps/authorizing-oauth-apps#web-application-flow
const fakeGitHubOAuthWebFlow = 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/github/authenticate?state=${stateSearchParam}&code=12345`;
resolve({ redirectUrl });
});
});
});
const [{ redirectUrl }] = await Promise.all([
fakeGitHubOAuthWebFlow,
page.getByText('Authenticate with GitHub').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: 'Authenticate' }).click();
await page
.locator('input[name="uri"]')
.fill('https://github.com/insomnia/example-repo');
await page.locator('data-testid=git-repository-settings-modal__sync-btn').click();
});