123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- import selectEvent from 'react-select-event';
- import {initializeOrg} from 'sentry-test/initializeOrg';
- import {
- render,
- screen,
- userEvent,
- waitFor,
- waitForElementToBeRemoved,
- } from 'sentry-test/reactTestingLibrary';
- import MemberListStore from 'sentry/stores/memberListStore';
- import ProjectsStore from 'sentry/stores/projectsStore';
- import TeamStore from 'sentry/stores/teamStore';
- import {Project} from 'sentry/types';
- import RuleBuilder from 'sentry/views/settings/project/projectOwnership/ruleBuilder';
- describe('RuleBuilder', function () {
- const {organization} = initializeOrg();
- let project: Project;
- let handleAdd: jest.Mock;
- const USER_1 = TestStubs.User({
- id: '1',
- name: 'Jane Bloggs',
- email: 'janebloggs@example.com',
- user: {
- id: '1',
- name: 'Jane Bloggs',
- email: 'janebloggs@example.com',
- },
- });
- const USER_2 = TestStubs.User({
- id: '2',
- name: 'John Smith',
- email: 'johnsmith@example.com',
- user: {
- id: '2',
- name: 'John Smith',
- email: 'johnsmith@example.com',
- },
- });
- const TEAM_1 = TestStubs.Team({
- id: '3',
- slug: 'cool-team',
- });
- // This team is in project
- const TEAM_2 = TestStubs.Team({
- id: '4',
- slug: 'team-not-in-project',
- });
- beforeEach(function () {
- // User in project
- MemberListStore.loadInitialData([USER_1]);
- // All teams
- jest.spyOn(TeamStore, 'getAll').mockImplementation(() => [TEAM_1, TEAM_2]);
- handleAdd = jest.fn();
- project = TestStubs.Project({
- // Teams in project
- teams: [TEAM_1],
- });
- ProjectsStore.loadInitialData([project]);
- jest.spyOn(ProjectsStore, 'getBySlug').mockImplementation(() => project);
- MockApiClient.clearMockResponses();
- MockApiClient.addMockResponse({
- url: '/organizations/org-slug/members/',
- body: [USER_1, USER_2],
- });
- });
- it('renders', async function () {
- const {container} = render(
- <RuleBuilder
- project={project}
- organization={organization}
- onAddRule={handleAdd}
- paths={[]}
- urls={[]}
- disabled={false}
- />
- );
- const addButton = screen.getByRole('button', {name: 'Add rule'});
- await userEvent.click(addButton);
- expect(handleAdd).not.toHaveBeenCalled();
- await userEvent.type(
- screen.getByRole('textbox', {name: 'Rule pattern'}),
- 'some/path/*'
- );
- expect(addButton).toBeDisabled();
- await selectEvent.select(
- screen.getByRole('textbox', {name: 'Rule owner'}),
- 'Jane Bloggs'
- );
- expect(addButton).toBeEnabled();
- await userEvent.click(addButton);
- expect(handleAdd).toHaveBeenCalled();
- expect(container).toSnapshot();
- });
- it('renders with suggestions', async function () {
- const {container} = render(
- <RuleBuilder
- project={project}
- organization={organization}
- onAddRule={handleAdd}
- urls={['example.com/a', 'example.com/a/foo']}
- paths={['a/bar', 'a/foo']}
- disabled={false}
- />
- );
- // Open the menu so we can do some assertions.
- const ownerInput = screen.getByRole('textbox', {name: 'Rule owner'});
- selectEvent.openMenu(ownerInput);
- await waitForElementToBeRemoved(() => screen.queryByText('Loading...'));
- expect(screen.getByText('Jane Bloggs')).toBeInTheDocument();
- expect(screen.getByText('John Smith')).toBeInTheDocument();
- expect(screen.getByText('#cool-team')).toBeInTheDocument();
- expect(screen.getByText('#team-not-in-project')).toBeInTheDocument();
- // TODO Check that the last two are disabled
- // Enter to select Jane Bloggs
- await selectEvent.select(ownerInput, 'Jane Bloggs');
- const candidates = screen.getAllByRole('button', {name: 'Path rule candidate'});
- await userEvent.click(candidates[0]);
- expect(screen.getByRole('textbox', {name: 'Rule pattern'})).toHaveValue('a/bar');
- const addButton = screen.getByRole('button', {name: 'Add rule'});
- await waitFor(() => expect(addButton).toBeEnabled());
- expect(container).toSnapshot();
- await userEvent.click(addButton);
- expect(handleAdd).toHaveBeenCalled();
- });
- it('builds a tag rule', async function () {
- render(
- <RuleBuilder
- project={project}
- organization={organization}
- onAddRule={handleAdd}
- paths={[]}
- urls={[]}
- disabled={false}
- />
- );
- await selectEvent.select(screen.getByText('Path'), 'Tag');
- await userEvent.type(screen.getByPlaceholderText('tag-name'), 'mytag');
- await userEvent.type(screen.getByPlaceholderText('tag-value'), 'value');
- await selectEvent.select(
- screen.getByRole('textbox', {name: 'Rule owner'}),
- 'Jane Bloggs'
- );
- await userEvent.click(screen.getByRole('button', {name: 'Add rule'}));
- expect(handleAdd).toHaveBeenCalledWith('tags.mytag:value janebloggs@example.com');
- });
- });
|