123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- import Cookies from 'js-cookie';
- import {render, screen} from 'sentry-test/reactTestingLibrary';
- import {Role} from 'sentry/components/acl/role';
- import ConfigStore from 'sentry/stores/configStore';
- describe('Role', function () {
- const organization = TestStubs.Organization({
- role: 'admin',
- orgRoleList: [
- {
- id: 'member',
- name: 'Member',
- desc: '...',
- minimumTeamRole: 'contributor',
- },
- {
- id: 'admin',
- name: 'Admin',
- desc: '...',
- minimumTeamRole: 'admin',
- },
- {
- id: 'manager',
- name: 'Manager',
- desc: '...',
- minimumTeamRole: 'admin',
- },
- {
- id: 'owner',
- name: 'Owner',
- desc: '...',
- minimumTeamRole: 'admin',
- },
- ],
- });
- const routerContext = TestStubs.routerContext([
- {
- organization,
- },
- ]);
- describe('as render prop', function () {
- const childrenMock = jest.fn().mockReturnValue(null);
- beforeEach(function () {
- childrenMock.mockClear();
- });
- it('has a sufficient role', function () {
- render(<Role role="admin">{childrenMock}</Role>, {context: routerContext});
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: true,
- });
- });
- it('has an insufficient role', function () {
- render(<Role role="manager">{childrenMock}</Role>, {
- context: routerContext,
- });
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: false,
- });
- });
- it('gives access to a superuser with insufficient role', function () {
- ConfigStore.config.user = {isSuperuser: true};
- Cookies.set = jest.fn();
- render(<Role role="owner">{childrenMock}</Role>, {context: routerContext});
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: true,
- });
- expect(Cookies.set).toHaveBeenCalledWith('su', 'test');
- ConfigStore.config.user = {isSuperuser: false};
- });
- it('does not give access to a made up role', function () {
- render(<Role role="abcdefg">{childrenMock}</Role>, {
- context: routerContext,
- });
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: false,
- });
- });
- it('handles no user', function () {
- const user = {...ConfigStore.config.user};
- ConfigStore.config.user = undefined;
- render(<Role role="member">{childrenMock}</Role>, {context: routerContext});
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: false,
- });
- ConfigStore.config.user = user;
- });
- it('updates if user changes', function () {
- const user = {...ConfigStore.config.user};
- ConfigStore.config.user = undefined;
- const {rerender} = render(<Role role="member">{childrenMock}</Role>, {
- context: routerContext,
- });
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: false,
- });
- ConfigStore.config.user = user;
- rerender(<Role role="member">{childrenMock}</Role>);
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: true,
- });
- });
- it('handles no organization.orgRoleList', function () {
- render(
- <Role role="member" organization={{...organization, orgRoleList: undefined}}>
- {childrenMock}
- </Role>,
- {context: routerContext}
- );
- expect(childrenMock).toHaveBeenCalledWith({
- hasRole: false,
- });
- });
- });
- describe('as React node', function () {
- it('has a sufficient role', function () {
- render(
- <Role role="member">
- <div>The Child</div>
- </Role>,
- {context: routerContext}
- );
- expect(screen.getByText('The Child')).toBeInTheDocument();
- });
- it('has an insufficient role', function () {
- render(
- <Role role="owner">
- <div>The Child</div>
- </Role>,
- {context: routerContext}
- );
- expect(screen.queryByText('The Child')).not.toBeInTheDocument();
- });
- });
- });
|