123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- import {render, screen} from 'sentry-test/reactTestingLibrary';
- import {textWithMarkupMatcher} from 'sentry-test/utils';
- import hydrateSpans from 'sentry/utils/replays/hydrateSpans';
- import useProjectSdkNeedsUpdate from 'sentry/utils/useProjectSdkNeedsUpdate';
- import {Output} from 'sentry/views/replays/detail/network/details/getOutputType';
- jest.mock('sentry/utils/useProjectSdkNeedsUpdate');
- import {Setup} from 'sentry/views/replays/detail/network/details/onboarding';
- const [MOCK_ITEM] = hydrateSpans(TestStubs.ReplayRecord(), [
- TestStubs.Replay.RequestFrame({
- op: 'resource.fetch',
- startTimestamp: new Date(),
- endTimestamp: new Date(),
- description: '/api/0/issues/1234',
- }),
- ]);
- describe('Setup', () => {
- jest
- .mocked(useProjectSdkNeedsUpdate)
- .mockReturnValue({isFetching: false, needsUpdate: false});
- describe('Setup is not complete', () => {
- it('should render the full snippet when no setup is done yet', () => {
- const {container} = render(
- <Setup
- item={MOCK_ITEM}
- projectId="0"
- showSnippet={Output.SETUP}
- visibleTab="details"
- />
- );
- expect(
- screen.getByText('Capture Request and Response Headers and Bodies')
- ).toBeInTheDocument();
- expect(container.querySelector('code')).toHaveTextContent(
- `networkRequestHeaders: ['X-Custom-Header'],`
- );
- });
- });
- describe('Url is skipped', () => {
- it('should render a note on the Details tab to allow this url', () => {
- render(
- <Setup
- item={MOCK_ITEM}
- projectId="0"
- showSnippet={Output.URL_SKIPPED}
- visibleTab="details"
- />
- );
- expect(
- screen.getByText('Capture Request and Response Headers')
- ).toBeInTheDocument();
- expect(
- screen.getByText(
- textWithMarkupMatcher(
- 'Add the following to your networkDetailAllowUrls list to start capturing data:'
- )
- )
- ).toBeInTheDocument();
- });
- it('should render a note on the Requst & Response tabs to allow this url and enable capturing bodies', () => {
- render(
- <Setup
- item={MOCK_ITEM}
- projectId="0"
- showSnippet={Output.URL_SKIPPED}
- visibleTab="request"
- />
- );
- expect(screen.getByText('Capture Request and Response Bodies')).toBeInTheDocument();
- expect(
- screen.getByText(
- textWithMarkupMatcher(
- 'Add the following to your networkDetailAllowUrls list to start capturing data:'
- )
- )
- ).toBeInTheDocument();
- });
- });
- describe('Body is skipped', () => {
- it('should render a note on the Requst & Response tabs to enable capturing bodies', () => {
- render(
- <Setup
- item={MOCK_ITEM}
- projectId="0"
- showSnippet={Output.BODY_SKIPPED}
- visibleTab="request"
- />
- );
- expect(screen.getByText('Capture Request and Response Bodies')).toBeInTheDocument();
- expect(
- screen.getByText(
- textWithMarkupMatcher(
- 'Enable networkCaptureBodies: true to capture both Request and Response bodies.'
- )
- )
- ).toBeInTheDocument();
- });
- });
- describe('Showing the data', () => {
- it('should render a short message reminding you to configure custom headers', () => {
- render(
- <Setup
- item={MOCK_ITEM}
- projectId="0"
- showSnippet={Output.DATA}
- visibleTab="details"
- />
- );
- expect(
- screen.getByText(
- textWithMarkupMatcher(
- 'You can capture additional headers by adding them to the networkRequestHeaders and networkResponseHeaders lists in your SDK config.'
- )
- )
- ).toBeInTheDocument();
- });
- });
- });
|