123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- import {GroupFixture} from 'sentry-fixture/group';
- import {ProjectFixture} from 'sentry-fixture/project';
- import {UserFixture} from 'sentry-fixture/user';
- import {
- render,
- renderGlobalModal,
- screen,
- userEvent,
- } from 'sentry-test/reactTestingLibrary';
- import ConfigStore from 'sentry/stores/configStore';
- import GroupStore from 'sentry/stores/groupStore';
- import ProjectsStore from 'sentry/stores/projectsStore';
- import type {GroupActivity} from 'sentry/types/group';
- import {GroupActivityType} from 'sentry/types/group';
- import StreamlinedActivitySection from 'sentry/views/issueDetails/streamline/activitySection';
- describe('StreamlinedActivitySection', function () {
- const project = ProjectFixture();
- const user = UserFixture();
- user.options.prefersIssueDetailsStreamlinedUI = true;
- ConfigStore.set('user', user);
- ProjectsStore.loadInitialData([project]);
- GroupStore.init();
- const group = GroupFixture({
- id: '1337',
- activity: [
- {
- type: GroupActivityType.NOTE,
- id: 'note-1',
- data: {text: 'Test Note'},
- dateCreated: '2020-01-01T00:00:00',
- user: user,
- project,
- },
- ],
- project,
- });
- GroupStore.add([group]);
- beforeEach(() => {
- jest.restoreAllMocks();
- MockApiClient.clearMockResponses();
- });
- it('renders the input with a comment button', async function () {
- const comment = 'nice work friends';
- const postMock = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/issues/1337/comments/',
- method: 'POST',
- body: {
- id: 'note-2',
- user: UserFixture({id: '2'}),
- type: 'note',
- data: {text: comment},
- dateCreated: '2024-10-31T00:00:00.000000Z',
- },
- });
- render(<StreamlinedActivitySection group={group} />);
- const commentInput = screen.getByRole('textbox', {name: 'Add a comment'});
- expect(commentInput).toBeInTheDocument();
- expect(
- screen.queryByRole('button', {name: 'Submit comment'})
- ).not.toBeInTheDocument();
- await userEvent.click(commentInput);
- // Button appears after input is focused
- const submitButton = await screen.findByRole('button', {name: 'Submit comment'});
- expect(submitButton).toBeInTheDocument();
- expect(submitButton).toBeDisabled();
- await userEvent.type(commentInput, comment);
- expect(submitButton).toBeEnabled();
- await userEvent.click(submitButton);
- expect(postMock).toHaveBeenCalled();
- });
- it('allows submitting the comment field with hotkeys', async function () {
- const comment = 'nice work friends';
- const postMock = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/issues/1337/comments/',
- method: 'POST',
- body: {
- id: 'note-3',
- user: UserFixture({id: '2'}),
- type: 'note',
- data: {text: comment},
- dateCreated: '2024-10-31T00:00:00.000000Z',
- },
- });
- render(<StreamlinedActivitySection group={group} />);
- const commentInput = screen.getByRole('textbox', {name: 'Add a comment'});
- await userEvent.type(commentInput, comment);
- await userEvent.keyboard('{Meta>}{Enter}{/Meta}');
- expect(postMock).toHaveBeenCalled();
- });
- it('renders note and allows for delete', async function () {
- const deleteMock = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/issues/1337/comments/note-1/',
- method: 'DELETE',
- });
- render(<StreamlinedActivitySection group={group} />);
- renderGlobalModal();
- expect(await screen.findByText('Test Note')).toBeInTheDocument();
- expect(screen.getByRole('button', {name: 'Comment Actions'})).toBeInTheDocument();
- await userEvent.click(screen.getByRole('button', {name: 'Comment Actions'}));
- await userEvent.click(screen.getByRole('menuitemradio', {name: 'Remove'}));
- expect(
- screen.getByText('Are you sure you want to remove this comment?')
- ).toBeInTheDocument();
- await userEvent.click(screen.getByRole('button', {name: 'Remove comment'}));
- expect(deleteMock).toHaveBeenCalledTimes(1);
- expect(screen.queryByText('Test Note')).not.toBeInTheDocument();
- });
- it('renders note but does not allow for deletion if written by someone else', async function () {
- const updatedActivityGroup = GroupFixture({
- id: '1338',
- activity: [
- {
- type: GroupActivityType.NOTE,
- id: 'note-1',
- data: {text: 'Test Note'},
- dateCreated: '2020-01-01T00:00:00',
- user: UserFixture({id: '2'}),
- project,
- },
- ],
- project,
- });
- render(<StreamlinedActivitySection group={updatedActivityGroup} />);
- expect(await screen.findByText('Test Note')).toBeInTheDocument();
- expect(
- screen.queryByRole('button', {name: 'Comment Actions'})
- ).not.toBeInTheDocument();
- });
- it('collapses activity when there are more than 5 items', async function () {
- const activities: GroupActivity[] = Array.from({length: 7}, (_, index) => ({
- type: GroupActivityType.NOTE,
- id: `note-${index + 1}`,
- data: {text: `Test Note ${index + 1}`},
- dateCreated: '2020-01-01T00:00:00',
- user: UserFixture({id: '2'}),
- project,
- }));
- const updatedActivityGroup = GroupFixture({
- id: '1338',
- activity: activities,
- project,
- });
- render(<StreamlinedActivitySection group={updatedActivityGroup} />);
- expect(await screen.findByText('Test Note 1')).toBeInTheDocument();
- expect(await screen.findByText('Test Note 7')).toBeInTheDocument();
- expect(screen.queryByText('Test Note 6')).not.toBeInTheDocument();
- expect(await screen.findByText('4 activities hidden')).toBeInTheDocument();
- await userEvent.click(await screen.findByRole('button', {name: 'Show all activity'}));
- expect(await screen.findByText('Test Note 6')).toBeInTheDocument();
- });
- });
|