mirror of
https://github.com/enso-org/enso.git
synced 2024-12-21 17:21:37 +03:00
83ec24da59
- PARTIALLY implements https://github.com/enso-org/cloud-v2/issues/1232 - Partially refactor E2E test actions into a state machine. - The main goal of this is to _disallow_ invalid actions - for example going from a page to itself, which will fail at runtime, or trying to create a new Data Link on a page where that button is not accessible. - An auxiliary goal is to have better namespacing of actions and better clarity: - Previously, everything was a locator at the top level of a single module. This makes it very difficult to comprehend what kinds of actions are available. - Note: There is also older `namespace`-based namespacing for the User and Organization settings pages, which were added before this refactor. They SHOULD be refactored to the new API, but I'm not sure whether it's worth spending the time right now. - Add E2E tests for every input on the "user" settings page and the "organization" settings page. - A skeletal E2E test for the Datalink modal has also been added - it does not actually test anything currently but should be sufficient for building upon. # Important Notes None
29 lines
978 B
TypeScript
29 lines
978 B
TypeScript
/** @file Actions for the "settings" page. */
|
|
import BaseActions from './BaseActions'
|
|
import * as goToPageActions from './goToPageActions'
|
|
import * as openUserMenuAction from './openUserMenuAction'
|
|
import * as userMenuActions from './userMenuActions'
|
|
|
|
// ===========================
|
|
// === SettingsPageActions ===
|
|
// ===========================
|
|
|
|
// TODO: split settings page actions into different classes for each settings tab.
|
|
/** Actions for the "settings" page. */
|
|
export default class SettingsPageActions extends BaseActions {
|
|
/** Actions for navigating to another page. */
|
|
get goToPage(): Omit<goToPageActions.GoToPageActions, 'settings'> {
|
|
return goToPageActions.goToPageActions(this.step.bind(this))
|
|
}
|
|
|
|
/** Actions related to the User Menu. */
|
|
get userMenu() {
|
|
return userMenuActions.userMenuActions(this.step.bind(this))
|
|
}
|
|
|
|
/** Open the User Menu. */
|
|
openUserMenu() {
|
|
return openUserMenuAction.openUserMenuAction(this.step.bind(this))
|
|
}
|
|
}
|