123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- import {ConfigFixture} from 'sentry-fixture/config';
- import {UserFixture} from 'sentry-fixture/user';
- import ConfigStore from 'sentry/stores/configStore';
- import GuideStore from 'sentry/stores/guideStore';
- import ModalStore from 'sentry/stores/modalStore';
- import {trackAnalytics} from 'sentry/utils/analytics';
- jest.mock('sentry/utils/analytics');
- describe('GuideStore', function () {
- let data!: Parameters<typeof GuideStore.fetchSucceeded>[0];
- beforeEach(function () {
- jest.clearAllMocks();
- ConfigStore.loadInitialData(
- ConfigFixture({
- user: UserFixture({
- id: '5',
- isSuperuser: false,
- dateJoined: '2020-01-01T00:00:00',
- }),
- })
- );
- GuideStore.init();
- data = [
- {
- guide: 'issue',
- seen: false,
- },
- {guide: 'issue_stream', seen: true},
- ];
- GuideStore.registerAnchor('issue_header_stats');
- GuideStore.registerAnchor('issue_sidebar_owners');
- GuideStore.registerAnchor('breadcrumbs');
- GuideStore.registerAnchor('issue_stream');
- });
- afterEach(() => {
- GuideStore.teardown();
- });
- it('should move through the steps in the guide', function () {
- GuideStore.fetchSucceeded(data);
- // Should pick the first non-seen guide in alphabetic order.
- expect(GuideStore.getState().currentStep).toBe(0);
- expect(GuideStore.getState().currentGuide?.guide).toBe('issue');
- // Should prune steps that don't have anchors.
- expect(GuideStore.getState().currentGuide?.steps).toHaveLength(3);
- GuideStore.nextStep();
- expect(GuideStore.getState().currentStep).toBe(1);
- GuideStore.nextStep();
- expect(GuideStore.getState().currentStep).toBe(2);
- GuideStore.closeGuide();
- expect(GuideStore.getState().currentGuide).toBeNull();
- });
- it('should force show a guide with #assistant', function () {
- data = [
- {
- guide: 'issue',
- seen: true,
- },
- {guide: 'issue_stream', seen: false},
- ];
- GuideStore.fetchSucceeded(data);
- window.location.hash = '#assistant';
- window.dispatchEvent(new Event('load'));
- expect(GuideStore.getState().currentGuide?.guide).toBe('issue');
- GuideStore.closeGuide();
- expect(GuideStore.getState().currentGuide?.guide).toBe('issue_stream');
- window.location.hash = '';
- });
- it('should force hide', function () {
- expect(GuideStore.state.forceHide).toBe(false);
- GuideStore.setForceHide(true);
- expect(GuideStore.state.forceHide).toBe(true);
- GuideStore.setForceHide(false);
- expect(GuideStore.state.forceHide).toBe(false);
- });
- it('should record analytics events when guide is cued', function () {
- const spy = jest.spyOn(GuideStore, 'recordCue');
- GuideStore.fetchSucceeded(data);
- expect(spy).toHaveBeenCalledWith('issue');
- expect(trackAnalytics).toHaveBeenCalledWith('assistant.guide_cued', {
- guide: 'issue',
- organization: null,
- });
- expect(spy).toHaveBeenCalledTimes(1);
- window.dispatchEvent(new Event('load'));
- expect(spy).toHaveBeenCalledTimes(1);
- GuideStore.nextStep();
- expect(spy).toHaveBeenCalledTimes(1);
- spy.mockRestore();
- });
- it('only shows guides with server data and content', function () {
- data = [
- {
- guide: 'issue',
- seen: true,
- },
- {
- guide: 'has_no_content',
- seen: false,
- },
- ];
- GuideStore.fetchSucceeded(data);
- expect(GuideStore.state.guides).toHaveLength(1);
- expect(GuideStore.state.guides[0]!.guide).toBe(data[0]!.guide);
- });
- it('hides when a modal is open', function () {
- expect(GuideStore.getState().forceHide).toBe(false);
- ModalStore.openModal(() => <div />, {});
- expect(GuideStore.getState().forceHide).toBe(true);
- ModalStore.closeModal();
- expect(GuideStore.getState().forceHide).toBe(false);
- });
- it('should return a stable reference from getState', function () {
- ModalStore.openModal(() => <div />, {});
- const state = GuideStore.getState();
- expect(Object.is(state, GuideStore.getState())).toBe(true);
- });
- });
|