mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-31 15:37:26 -08:00
fix(editor): Resolve going back from Settings (#11958)
This commit is contained in:
parent
90f8b09af0
commit
d74423c751
|
@ -219,7 +219,7 @@ const onUserActionToggle = (action: string) => {
|
||||||
onLogout();
|
onLogout();
|
||||||
break;
|
break;
|
||||||
case 'settings':
|
case 'settings':
|
||||||
void router.push({ name: VIEWS.PERSONAL_SETTINGS });
|
void router.push({ name: VIEWS.SETTINGS });
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -487,6 +487,7 @@ export const enum VIEWS {
|
||||||
SETUP = 'SetupView',
|
SETUP = 'SetupView',
|
||||||
FORGOT_PASSWORD = 'ForgotMyPasswordView',
|
FORGOT_PASSWORD = 'ForgotMyPasswordView',
|
||||||
CHANGE_PASSWORD = 'ChangePasswordView',
|
CHANGE_PASSWORD = 'ChangePasswordView',
|
||||||
|
SETTINGS = 'Settings',
|
||||||
USERS_SETTINGS = 'UsersSettings',
|
USERS_SETTINGS = 'UsersSettings',
|
||||||
LDAP_SETTINGS = 'LdapSettings',
|
LDAP_SETTINGS = 'LdapSettings',
|
||||||
PERSONAL_SETTINGS = 'PersonalSettings',
|
PERSONAL_SETTINGS = 'PersonalSettings',
|
||||||
|
|
|
@ -480,8 +480,10 @@ export const routes: RouteRecordRaw[] = [
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: '/settings',
|
path: '/settings',
|
||||||
|
name: VIEWS.SETTINGS,
|
||||||
component: SettingsView,
|
component: SettingsView,
|
||||||
props: true,
|
props: true,
|
||||||
|
redirect: { name: VIEWS.USAGE },
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
path: 'usage',
|
path: 'usage',
|
||||||
|
|
122
packages/editor-ui/src/views/SettingsView.test.ts
Normal file
122
packages/editor-ui/src/views/SettingsView.test.ts
Normal file
|
@ -0,0 +1,122 @@
|
||||||
|
import { createTestingPinia } from '@pinia/testing';
|
||||||
|
import { createRouter, createWebHistory } from 'vue-router';
|
||||||
|
import userEvent from '@testing-library/user-event';
|
||||||
|
import { createComponentRenderer } from '@/__tests__/render';
|
||||||
|
import SettingsView from '@/views/SettingsView.vue';
|
||||||
|
import { VIEWS } from '@/constants';
|
||||||
|
import { routes as originalRoutes } from '@/router';
|
||||||
|
|
||||||
|
const component = { template: '<div />' };
|
||||||
|
const settingsRoute = originalRoutes.find((route) => route.name === VIEWS.SETTINGS);
|
||||||
|
|
||||||
|
const settingsRouteChildren =
|
||||||
|
settingsRoute?.children?.map(({ name, path }) => ({
|
||||||
|
name,
|
||||||
|
path,
|
||||||
|
component,
|
||||||
|
})) ?? [];
|
||||||
|
|
||||||
|
const router = createRouter({
|
||||||
|
history: createWebHistory(),
|
||||||
|
routes: [
|
||||||
|
{
|
||||||
|
path: '/',
|
||||||
|
redirect: '/home',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/home',
|
||||||
|
name: 'Homepage',
|
||||||
|
redirect: '/home/workflows',
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
path: 'workflows',
|
||||||
|
name: 'Workflows',
|
||||||
|
component,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'credentials',
|
||||||
|
name: 'Credentials',
|
||||||
|
component,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'executions',
|
||||||
|
name: 'Executions',
|
||||||
|
component,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/settings',
|
||||||
|
name: VIEWS.SETTINGS,
|
||||||
|
component: SettingsView,
|
||||||
|
props: true,
|
||||||
|
redirect: { name: VIEWS.USAGE },
|
||||||
|
children: settingsRouteChildren,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
const renderView = createComponentRenderer(SettingsView, {
|
||||||
|
pinia: createTestingPinia(),
|
||||||
|
global: {
|
||||||
|
plugins: [router],
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const renderApp = createComponentRenderer(
|
||||||
|
{
|
||||||
|
template: '<router-view />',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
pinia: createTestingPinia(),
|
||||||
|
global: {
|
||||||
|
plugins: [router],
|
||||||
|
stubs: {
|
||||||
|
SettingsSidebar: {
|
||||||
|
template: '<div><button data-test-id="back" @click="$emit(\'return\')"></button></div>',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
describe('SettingsView', () => {
|
||||||
|
it('should render the view without throwing', () => {
|
||||||
|
expect(() => renderView()).not.toThrow();
|
||||||
|
});
|
||||||
|
|
||||||
|
test.each([
|
||||||
|
['/', ['/settings', '/settings/users'], '/home/workflows'],
|
||||||
|
['/home', ['/settings', '/settings/users'], '/home/workflows'],
|
||||||
|
['/home/workflows', ['/settings', '/settings/personal'], '/home/workflows'],
|
||||||
|
[
|
||||||
|
'/home/credentials',
|
||||||
|
['/settings', '/settings/personal', '/settings/api', '/settings/environments'],
|
||||||
|
'/home/credentials',
|
||||||
|
],
|
||||||
|
['/home/executions', ['/settings'], '/home/executions'],
|
||||||
|
['/settings', [], '/home/workflows'],
|
||||||
|
[
|
||||||
|
'/settings',
|
||||||
|
['/settings/personal', '/settings/api', '/settings/environments'],
|
||||||
|
'/home/workflows',
|
||||||
|
],
|
||||||
|
['/settings/personal', [], '/home/workflows'],
|
||||||
|
['/settings/usage', ['/settings/api', '/settings/environments'], '/home/workflows'],
|
||||||
|
])(
|
||||||
|
'should start from "%s" and visit %s routes and go back to "%s"',
|
||||||
|
async (startRoute, routes, expectedRoute) => {
|
||||||
|
const { getByTestId } = renderApp();
|
||||||
|
|
||||||
|
await router.push(startRoute);
|
||||||
|
|
||||||
|
for (const route of routes) {
|
||||||
|
await router.push(route);
|
||||||
|
}
|
||||||
|
|
||||||
|
await userEvent.click(getByTestId('back'));
|
||||||
|
|
||||||
|
expect(router.currentRoute.value.path).toBe(expectedRoute);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
});
|
|
@ -11,9 +11,16 @@ const router = useRouter();
|
||||||
const previousRoute = ref<HistoryState[string] | undefined>();
|
const previousRoute = ref<HistoryState[string] | undefined>();
|
||||||
|
|
||||||
function onReturn() {
|
function onReturn() {
|
||||||
void router.push(
|
const resolvedSettingsRoute = router.resolve({ name: VIEWS.SETTINGS });
|
||||||
isRouteLocationRaw(previousRoute.value) ? previousRoute.value : { name: VIEWS.HOMEPAGE },
|
const resolvedPreviousRoute = isRouteLocationRaw(previousRoute.value)
|
||||||
);
|
? router.resolve(previousRoute.value)
|
||||||
|
: null;
|
||||||
|
const backRoute =
|
||||||
|
!resolvedPreviousRoute || resolvedPreviousRoute.path.startsWith(resolvedSettingsRoute.path)
|
||||||
|
? { name: VIEWS.HOMEPAGE }
|
||||||
|
: resolvedPreviousRoute;
|
||||||
|
|
||||||
|
void router.push(backRoute);
|
||||||
}
|
}
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
|
|
Loading…
Reference in a new issue