add test for removing owner

This commit is contained in:
Mikhail Mikheev 2019-06-28 17:06:33 +04:00
parent 8d82e19fcc
commit 93a3731160
6 changed files with 70 additions and 8 deletions

View File

@ -1,10 +1,10 @@
// @flow // @flow
import * as React from 'react' import * as React from 'react'
import classNames from 'classnames' import classNames from 'classnames'
import { getNamesFrom, getAccountsFrom } from '~/routes/open/utils/safeDataExtractor'
import Block from '~/components/layout/Block'
import { withStyles } from '@material-ui/core/styles' import { withStyles } from '@material-ui/core/styles'
import OpenInNew from '@material-ui/icons/OpenInNew' import OpenInNew from '@material-ui/icons/OpenInNew'
import { getNamesFrom, getAccountsFrom } from '~/routes/open/utils/safeDataExtractor'
import Block from '~/components/layout/Block'
import Identicon from '~/components/Identicon' import Identicon from '~/components/Identicon'
import OpenPaper from '~/components/Stepper/OpenPaper' import OpenPaper from '~/components/Stepper/OpenPaper'
import Col from '~/components/layout/Col' import Col from '~/components/layout/Col'

View File

@ -17,6 +17,8 @@ import { getEtherScanLink } from '~/logic/wallets/getWeb3'
import { styles } from './style' import { styles } from './style'
import { secondary } from '~/theme/variables' import { secondary } from '~/theme/variables'
export const REMOVE_OWNER_MODAL_NEXT_BTN_TESTID = 'remove-owner-next-btn'
const openIconStyle = { const openIconStyle = {
height: '16px', height: '16px',
color: secondary, color: secondary,
@ -93,6 +95,7 @@ const CheckOwner = ({
minWidth={140} minWidth={140}
color="primary" color="primary"
onClick={handleSubmit} onClick={handleSubmit}
testId={REMOVE_OWNER_MODAL_NEXT_BTN_TESTID}
> >
Next Next
</Button> </Button>

View File

@ -19,6 +19,8 @@ import { getEtherScanLink } from '~/logic/wallets/getWeb3'
import { secondary } from '~/theme/variables' import { secondary } from '~/theme/variables'
import { styles } from './style' import { styles } from './style'
export const REMOVE_OWNER_REVIEW_BTN_TESTID = 'remove-owner-review-btn'
const openIconStyle = { const openIconStyle = {
height: '16px', height: '16px',
color: secondary, color: secondary,
@ -180,7 +182,7 @@ const ReviewRemoveOwner = ({
variant="contained" variant="contained"
minWidth={140} minWidth={140}
color="primary" color="primary"
data-testid="review-tx-btn" testId={REMOVE_OWNER_REVIEW_BTN_TESTID}
> >
Submit Submit
</Button> </Button>

View File

@ -20,6 +20,8 @@ import {
} from '~/components/forms/validator' } from '~/components/forms/validator'
import { styles } from './style' import { styles } from './style'
export const REMOVE_OWNER_THRESHOLD_NEXT_BTN_TESTID = 'remove-owner-threshold-next-btn'
type Props = { type Props = {
onClose: () => void, onClose: () => void,
classes: Object, classes: Object,
@ -112,7 +114,7 @@ owner(s)
variant="contained" variant="contained"
minWidth={140} minWidth={140}
color="primary" color="primary"
data-testid="review-tx-btn" data-testid={REMOVE_OWNER_THRESHOLD_NEXT_BTN_TESTID}
> >
Review Review
</Button> </Button>

View File

@ -29,6 +29,7 @@ import RenameOwnerIcon from './assets/icons/rename-owner.svg'
import RemoveOwnerIcon from '../assets/icons/bin.svg' import RemoveOwnerIcon from '../assets/icons/bin.svg'
export const RENAME_OWNER_BTN_TESTID = 'rename-owner-btn' export const RENAME_OWNER_BTN_TESTID = 'rename-owner-btn'
export const REMOVE_OWNER_BTN_TESTID = 'remove-owner-btn'
export const OWNERS_ROW_TESTID = 'owners-row' export const OWNERS_ROW_TESTID = 'owners-row'
const controlsStyle = { const controlsStyle = {
@ -153,6 +154,7 @@ class ManageOwners extends React.Component<Props, State> {
className={classes.removeOwnerIcon} className={classes.removeOwnerIcon}
src={RemoveOwnerIcon} src={RemoveOwnerIcon}
onClick={this.onShow('RemoveOwner', row)} onClick={this.onShow('RemoveOwner', row)}
testId={REMOVE_OWNER_BTN_TESTID}
/> />
</Row> </Row>
</TableCell> </TableCell>

View File

@ -7,8 +7,18 @@ import { sleep } from '~/utils/timer'
import 'jest-dom/extend-expect' import 'jest-dom/extend-expect'
import { SETTINGS_TAB_BTN_TESTID } from '~/routes/safe/components/Layout' import { SETTINGS_TAB_BTN_TESTID } from '~/routes/safe/components/Layout'
import { OWNERS_SETTINGS_TAB_TEST_ID } from '~/routes/safe/components/Settings' import { OWNERS_SETTINGS_TAB_TEST_ID } from '~/routes/safe/components/Settings'
import { RENAME_OWNER_BTN_TESTID, OWNERS_ROW_TESTID } from '~/routes/safe/components/Settings/ManageOwners' import {
import { RENAME_OWNER_INPUT_TESTID, SAVE_OWNER_CHANGES_BTN_TESTID } from '~/routes/safe/components/Settings/ManageOwners/EditOwnerModal' RENAME_OWNER_BTN_TESTID,
OWNERS_ROW_TESTID,
REMOVE_OWNER_BTN_TESTID,
} from '~/routes/safe/components/Settings/ManageOwners'
import {
RENAME_OWNER_INPUT_TESTID,
SAVE_OWNER_CHANGES_BTN_TESTID,
} from '~/routes/safe/components/Settings/ManageOwners/EditOwnerModal'
import { REMOVE_OWNER_MODAL_NEXT_BTN_TESTID } from '~/routes/safe/components/Settings/ManageOwners/RemoveOwnerModal/screens/CheckOwner'
import { REMOVE_OWNER_THRESHOLD_NEXT_BTN_TESTID } from '~/routes/safe/components/Settings/ManageOwners/RemoveOwnerModal/screens/ThresholdForm'
import { REMOVE_OWNER_REVIEW_BTN_TESTID } from '~/routes/safe/components/Settings/ManageOwners/RemoveOwnerModal/screens/Review'
afterEach(cleanup) afterEach(cleanup)
@ -17,11 +27,10 @@ describe('DOM > Feature > Settings - Manage owners', () => {
let safeAddress let safeAddress
beforeEach(async () => { beforeEach(async () => {
store = aNewStore() store = aNewStore()
// using 4th account because other accounts were used in other tests and paid gas
safeAddress = await aMinedSafe(store) safeAddress = await aMinedSafe(store)
}) })
it('Changes owner\'s name', async () => { it("Changes owner's name", async () => {
const NEW_OWNER_NAME = 'NEW OWNER NAME' const NEW_OWNER_NAME = 'NEW OWNER NAME'
const SafeDom = renderSafeView(store, safeAddress) const SafeDom = renderSafeView(store, safeAddress)
@ -52,4 +61,48 @@ describe('DOM > Feature > Settings - Manage owners', () => {
const ownerRow = SafeDom.getByTestId(OWNERS_ROW_TESTID) const ownerRow = SafeDom.getByTestId(OWNERS_ROW_TESTID)
expect(ownerRow).toHaveTextContent(NEW_OWNER_NAME) expect(ownerRow).toHaveTextContent(NEW_OWNER_NAME)
}) })
it('Removes an owner', async () => {
const twoOwnersSafeAddress = await aMinedSafe(store, 2)
const SafeDom = renderSafeView(store, twoOwnersSafeAddress)
await sleep(1300)
// Travel to settings
const settingsBtn = SafeDom.getByTestId(SETTINGS_TAB_BTN_TESTID)
fireEvent.click(settingsBtn)
await sleep(200)
// click on owners settings
const ownersSettingsBtn = SafeDom.getByTestId(OWNERS_SETTINGS_TAB_TEST_ID)
fireEvent.click(ownersSettingsBtn)
await sleep(200)
// check if there are 2 owners
let ownerRows = SafeDom.getAllByTestId(OWNERS_ROW_TESTID)
expect(ownerRows.length).toBe(2)
// click remove owner btn which opens the modal
const removeOwnerBtn = SafeDom.getAllByTestId(REMOVE_OWNER_BTN_TESTID)[1]
fireEvent.click(removeOwnerBtn)
// modal navigation
const nextBtnStep1 = SafeDom.getByTestId(REMOVE_OWNER_MODAL_NEXT_BTN_TESTID)
fireEvent.click(nextBtnStep1)
const nextBtnStep2 = SafeDom.getByTestId(REMOVE_OWNER_THRESHOLD_NEXT_BTN_TESTID)
fireEvent.click(nextBtnStep2)
const nextBtnStep3 = SafeDom.getByTestId(REMOVE_OWNER_REVIEW_BTN_TESTID)
fireEvent.click(nextBtnStep3)
await sleep(400)
// check if owner was removed
ownerRows = SafeDom.getAllByTestId(OWNERS_ROW_TESTID)
expect(ownerRows.length).toBe(1)
})
it('Replaces a owner', async () => {})
it('Adds a new owner', async () => {})
}) })