diff --git a/src/pages/tickets/__tests__/TicketModalPage.spec.tsx b/src/pages/tickets/__tests__/TicketModalPage.spec.tsx
index 7a9bd660..e0d87a29 100644
--- a/src/pages/tickets/__tests__/TicketModalPage.spec.tsx
+++ b/src/pages/tickets/__tests__/TicketModalPage.spec.tsx
@@ -1,5 +1,15 @@
import '@testing-library/jest-dom';
-import { act, render, waitFor, fireEvent, screen, within } from '@testing-library/react';
+import {
+ act,
+ render,
+ waitFor,
+ fireEvent,
+ screen,
+ within,
+ getByTestId,
+ getAllByText,
+ queryByText
+} from '@testing-library/react';
import { user } from '__test__/__mockData__/user';
import { mockBountiesMutated, newBounty } from 'bounties/__mock__/mockBounties.data';
import { DollarConverter, formatSat, getSessionValue, satToUsd } from 'helpers';
@@ -8,9 +18,10 @@ import { MemoryRouter, Route } from 'react-router-dom';
import { mainStore } from 'store/main';
import { useIsMobile } from 'hooks';
import { uiStore } from 'store/ui';
+import { unpaidString } from 'people/widgetViews/summaries/constants';
+import userEvent from '@testing-library/user-event';
import { TicketModalPage } from '../TicketModalPage';
import { withCreateModal } from '../../../components/common/withCreateModal';
-import { unpaidString } from 'people/widgetViews/summaries/constants';
jest.mock('hooks', () => ({
useIsMobile: jest.fn()
@@ -130,7 +141,7 @@ describe('TicketModalPage Component', () => {
}
+ render={(props: any) => }
/>
);
@@ -487,7 +498,7 @@ describe('TicketModalPage Component', () => {
expect(getByText(DollarConverter(mockBountiesMutated[1].body.price))).toBeInTheDocument();
// usd conversion
expect(
- getByText(satToUsd(parseInt(mockBountiesMutated[1].body.price)) + ' USD')
+ getByText(`${satToUsd(parseInt(mockBountiesMutated[1].body.price))} USD`)
).toBeInTheDocument();
screen.debug(undefined, Infinity);
// Estimated Hours
@@ -596,4 +607,229 @@ describe('TicketModalPage Component', () => {
});
});
});
+
+ it('test that if a bounty is open and I am the creator of the bounty, I should be able to invite a bounty hunter', async () => {
+ (useIsMobile as jest.Mock).mockReturnValue(false);
+ uiStore.setMeInfo(user);
+
+ jest.spyOn(mainStore, 'getBountyById').mockReturnValue(
+ Promise.resolve([
+ {
+ ...newBounty,
+ person: { ...newBounty.person, owner_alias: user.alias },
+ body: {
+ ...mockBountiesMutated[1].body,
+ owner: user
+ }
+ }
+ ])
+ );
+ jest.spyOn(mainStore, 'getBountyIndexById').mockReturnValue(Promise.resolve(1234));
+ jest.spyOn(mainStore, 'saveBounty').mockResolvedValue();
+
+ await act(async () => {
+ const { getByText } = render(
+
+
+
+ );
+
+ await waitFor(() => getByText('Not Assigned'));
+ fireEvent.click(getByText('Not Assigned'));
+
+ await waitFor(() => {
+ expect(getByText('Assign Developer')).toBeInTheDocument();
+ });
+ });
+ });
+
+ it('test that when I invite a new hunter, the hunter should be the assignee for that bounty', async () => {
+ (useIsMobile as jest.Mock).mockReturnValue(false);
+ uiStore.setMeInfo(user);
+
+ jest.spyOn(mainStore, 'getBountyById').mockReturnValue(
+ Promise.resolve([
+ {
+ ...newBounty,
+ person: { ...newBounty.person, owner_alias: user.alias },
+ body: {
+ ...mockBountiesMutated[1].body,
+ owner: user
+ }
+ }
+ ])
+ );
+ jest.spyOn(mainStore, 'getBountyIndexById').mockReturnValue(Promise.resolve(1234));
+ jest.spyOn(mainStore, 'saveBounty').mockResolvedValue();
+ jest.spyOn(mainStore, 'getPeopleByNameAliasPubkey').mockResolvedValue(
+ Promise.resolve([
+ {
+ id: 1,
+ owner_alias: 'TEST_NAME_1',
+ extras: {
+ coding_languages: [
+ { value: 'R', label: 'R' },
+ { value: 'C++', label: 'C++' }
+ ]
+ }
+ } as any
+ ])
+ );
+
+ await act(async () => {
+ const { getByText } = render(
+
+
+
+ );
+
+ await waitFor(() => getByText('Not Assigned'));
+ fireEvent.click(getByText('Not Assigned'));
+ await waitFor(() => {
+ expect(getByText('Assign Developer')).toBeInTheDocument();
+ });
+
+ fireEvent.click(screen.getByPlaceholderText('Type to search ...'));
+ await userEvent.type(screen.getByPlaceholderText('Type to search ...'), 'TEST_NAME');
+
+ await waitFor(() => getByText('TEST_NAME_1'));
+
+ fireEvent.click(screen.getAllByText('Assign')[0]);
+
+ jest.spyOn(mainStore, 'getBountyById').mockReturnValue(
+ Promise.resolve([
+ {
+ ...newBounty,
+ person: { ...newBounty.person, owner_alias: user.alias },
+ body: {
+ ...mockBountiesMutated[1].body,
+ owner: user
+ }
+ }
+ ])
+ );
+
+ await waitFor(() => {
+ expect(screen.queryByText('Assign Developer')).toBe(null);
+ expect(mainStore.saveBounty).toHaveBeenCalled();
+ expect(mainStore.getBountyById).toHaveBeenCalled();
+ });
+
+ expect(screen.getByText('Edit')).toBeInTheDocument();
+ expect(screen.getByText('TEST_NAME_1')).toBeInTheDocument();
+ });
+ });
+
+ it('test that the creator of a bounty can click on the Edit Bounty, and the Edit Modal should pop up', async () => {
+ (useIsMobile as jest.Mock).mockReturnValue(false);
+ uiStore.setMeInfo(user);
+
+ jest.spyOn(mainStore, 'getBountyById').mockReturnValue(
+ Promise.resolve([
+ {
+ ...newBounty,
+ person: { ...newBounty.person, owner_alias: user.alias },
+ body: {
+ ...mockBountiesMutated[1].body,
+ owner: user
+ }
+ }
+ ])
+ );
+ jest.spyOn(mainStore, 'getBountyIndexById').mockReturnValue(Promise.resolve(1234));
+ jest.spyOn(mainStore, 'saveBounty').mockResolvedValue();
+
+ await act(async () => {
+ const { getByText, getByTestId } = render(
+
+
+
+ );
+
+ await waitFor(() => getByText('Edit'));
+ fireEvent.click(getByText('Edit'));
+ await waitFor(() => getByText('Edit Bounty'));
+ expect(getByText('Edit Bounty')).toBeInTheDocument();
+ expect(getByText('Save')).toBeInTheDocument();
+ expect(getByText('Cancel')).toBeInTheDocument();
+ expect(getByTestId('testid-modal')).toBeInTheDocument();
+ });
+ });
+
+ it('test that when I click Save on the Edit Modal, an Edit action is carried out.', async () => {
+ (useIsMobile as jest.Mock).mockReturnValue(false);
+ uiStore.setMeInfo(user);
+
+ jest.spyOn(mainStore, 'getBountyById').mockReturnValue(
+ Promise.resolve([
+ {
+ ...newBounty,
+ person: { ...newBounty.person, owner_alias: user.alias },
+ body: {
+ ...mockBountiesMutated[1].body,
+ owner: user
+ }
+ }
+ ])
+ );
+ jest.spyOn(mainStore, 'getBountyIndexById').mockReturnValue(Promise.resolve(1234));
+ jest.spyOn(mainStore, 'saveBounty').mockResolvedValue();
+
+ await act(async () => {
+ const { getByText } = render(
+
+
+
+ );
+
+ await waitFor(() => getByText('Edit'));
+ fireEvent.click(getByText('Edit'));
+ await waitFor(() => getByText('Edit Bounty'));
+ expect(getByText('Edit Bounty')).toBeInTheDocument();
+
+ expect(getByText('Save')).toBeInTheDocument();
+ fireEvent.click(getByText('Save'));
+
+ await waitFor(() => getByText('Edit'));
+
+ await waitFor(() => {
+ expect(mainStore.saveBounty).toHaveBeenCalled();
+ });
+ });
+ });
+
+ it('test that when I click on Cancel on the Edit Modal, it hides the Edit Modal and shows the Bounty Modal', async () => {
+ (useIsMobile as jest.Mock).mockReturnValue(false);
+ uiStore.setMeInfo(user);
+
+ jest.spyOn(mainStore, 'getBountyById').mockReturnValue(
+ Promise.resolve([
+ {
+ ...newBounty,
+ person: { ...newBounty.person, owner_alias: user.alias },
+ body: {
+ ...mockBountiesMutated[1].body,
+ owner: user
+ }
+ }
+ ])
+ );
+ jest.spyOn(mainStore, 'getBountyIndexById').mockReturnValue(Promise.resolve(1234));
+
+ await act(async () => {
+ const { getByText, queryByText } = render(
+
+
+
+ );
+
+ await waitFor(() => getByText('Edit'));
+ fireEvent.click(getByText('Edit'));
+ await waitFor(() => getByText('Edit Bounty'));
+ fireEvent.click(getByText('Cancel'));
+ await waitFor(() => getByText('Edit'));
+ expect(queryByText('Edit Bounty')).not.toBeInTheDocument();
+ expect(queryByText('Edit')).toBeInTheDocument();
+ });
+ });
});