123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- import * as PropTypes from 'prop-types';
- import {
- render,
- renderGlobalModal,
- screen,
- userEvent,
- } from 'sentry-test/reactTestingLibrary';
- import ProjectKeyDetails from 'sentry/views/settings/project/projectKeys/details';
- describe('ProjectKeyDetails', function () {
- let org;
- let project;
- let deleteMock;
- let statsMock;
- let putMock;
- let projectKeys;
- beforeEach(function () {
- org = TestStubs.Organization();
- project = TestStubs.Project();
- projectKeys = TestStubs.ProjectKeys();
- MockApiClient.clearMockResponses();
- MockApiClient.addMockResponse({
- url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
- method: 'GET',
- body: projectKeys[0],
- });
- putMock = MockApiClient.addMockResponse({
- url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
- method: 'PUT',
- });
- statsMock = MockApiClient.addMockResponse({
- url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/stats/`,
- method: 'GET',
- body: [
- {filtered: 0, accepted: 0, total: 0, ts: 1517270400, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517356800, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517443200, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517529600, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517616000, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517702400, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517788800, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517875200, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1517961600, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518048000, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518134400, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518220800, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518307200, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518393600, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518480000, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518566400, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518652800, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518739200, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518825600, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518912000, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1518998400, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519084800, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519171200, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519257600, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519344000, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519430400, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519516800, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519603200, dropped: 0},
- {filtered: 0, accepted: 0, total: 0, ts: 1519689600, dropped: 0},
- {filtered: 0, accepted: 5, total: 12, ts: 1519776000, dropped: 7},
- {filtered: 0, accepted: 14, total: 14, ts: 1519862400, dropped: 0},
- ],
- });
- deleteMock = MockApiClient.addMockResponse({
- url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
- method: 'DELETE',
- });
- const context = {
- context: {
- project: TestStubs.Project(),
- },
- childContextTypes: {
- project: PropTypes.object,
- },
- };
- render(
- <ProjectKeyDetails
- routes={[]}
- params={{
- keyId: projectKeys[0].id,
- orgId: org.slug,
- projectId: project.slug,
- }}
- />,
- {context}
- );
- });
- it('has stats box', function () {
- expect(screen.getByText('Key Details')).toBeInTheDocument();
- expect(statsMock).toHaveBeenCalled();
- });
- it('changes name', function () {
- userEvent.clear(screen.getByRole('textbox', {name: 'Name'}));
- userEvent.type(screen.getByRole('textbox', {name: 'Name'}), 'New Name');
- userEvent.tab();
- expect(putMock).toHaveBeenCalledWith(
- `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
- expect.objectContaining({
- data: {
- name: 'New Name',
- },
- })
- );
- });
- it('disable and enables key', function () {
- userEvent.click(screen.getByRole('checkbox', {name: 'Enabled'}));
- expect(putMock).toHaveBeenCalledWith(
- `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
- expect.objectContaining({
- data: {isActive: false},
- })
- );
- userEvent.click(screen.getByRole('checkbox', {name: 'Enabled'}));
- expect(putMock).toHaveBeenCalledWith(
- `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
- expect.objectContaining({
- data: {isActive: false},
- })
- );
- });
- it('revokes a key', function () {
- userEvent.click(screen.getByRole('button', {name: 'Revoke Key'}));
- renderGlobalModal();
- userEvent.click(screen.getByTestId('confirm-button'));
- expect(deleteMock).toHaveBeenCalled();
- });
- });
|