123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438 |
- import React from 'react';
- import {mount} from 'enzyme';
- import Projects from 'app/utils/projects';
- import ProjectsStore from 'app/stores/projectsStore';
- describe('utils.projects', function() {
- const renderer = jest.fn(() => null);
- const createWrapper = props =>
- mount(<Projects orgId="org-slug" children={renderer} {...props} />); // eslint-disable-line
- beforeEach(function() {
- renderer.mockClear();
- MockApiClient.clearMockResponses();
- ProjectsStore.loadInitialData([
- TestStubs.Project({id: '1', slug: 'foo'}),
- TestStubs.Project({id: '2', slug: 'bar'}),
- ]);
- });
- afterEach(async function() {
- ProjectsStore.loadInitialData([]);
- await tick();
- });
- describe('with predefined list of slugs', function() {
- it('gets projects that are in the ProjectsStore ', async function() {
- const wrapper = createWrapper({slugs: ['foo', 'bar']});
- // This is initial state
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: false,
- isIncomplete: null,
- hasMore: null,
- projects: [
- expect.objectContaining({
- id: '1',
- slug: 'foo',
- }),
- expect.objectContaining({
- id: '2',
- slug: 'bar',
- }),
- ],
- })
- );
- await tick();
- wrapper.update();
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: false,
- isIncomplete: null,
- hasMore: null,
- projects: [
- expect.objectContaining({
- id: '1',
- slug: 'foo',
- }),
- expect.objectContaining({
- id: '2',
- slug: 'bar',
- }),
- ],
- })
- );
- });
- it('fetches projects from API if not found in store', async function() {
- const request = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/projects/',
- query: {
- query: 'slug:a slug:b',
- },
- body: [
- TestStubs.Project({
- id: '100',
- slug: 'a',
- }),
- TestStubs.Project({
- id: '101',
- slug: 'b',
- }),
- ],
- });
- const wrapper = createWrapper({slugs: ['foo', 'a', 'b']});
- // This is initial state
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: true,
- isIncomplete: null,
- hasMore: null,
- projects: [
- {slug: 'a'},
- {slug: 'b'},
- expect.objectContaining({
- id: '1',
- slug: 'foo',
- }),
- ],
- })
- );
- await tick();
- wrapper.update();
- expect(request).toHaveBeenCalledWith(
- expect.anything(),
- expect.objectContaining({
- query: {
- query: 'slug:a slug:b',
- },
- })
- );
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: false,
- isIncomplete: false,
- hasMore: null,
- projects: [
- expect.objectContaining({
- id: '100',
- slug: 'a',
- }),
- expect.objectContaining({
- id: '101',
- slug: 'b',
- }),
- expect.objectContaining({
- id: '1',
- slug: 'foo',
- }),
- ],
- })
- );
- });
- it('only has partial results from API', async function() {
- const request = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/projects/',
- body: [
- TestStubs.Project({
- id: '100',
- slug: 'a',
- }),
- ],
- });
- const wrapper = createWrapper({slugs: ['foo', 'a', 'b']});
- // This is initial state
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: true,
- isIncomplete: null,
- hasMore: null,
- projects: [
- {slug: 'a'},
- {slug: 'b'},
- expect.objectContaining({
- id: '1',
- slug: 'foo',
- }),
- ],
- })
- );
- await tick();
- wrapper.update();
- expect(request).toHaveBeenCalledWith(
- expect.anything(),
- expect.objectContaining({
- query: {
- query: 'slug:a slug:b',
- },
- })
- );
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: false,
- isIncomplete: true,
- hasMore: null,
- projects: [
- expect.objectContaining({
- id: '100',
- slug: 'a',
- }),
- {
- slug: 'b',
- },
- expect.objectContaining({
- id: '1',
- slug: 'foo',
- }),
- ],
- })
- );
- });
- });
- describe('with no pre-defined projects', function() {
- let request;
- beforeEach(async function() {
- request = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/projects/',
- body: [
- TestStubs.Project({
- id: '100',
- slug: 'a',
- }),
- TestStubs.Project({
- id: '101',
- slug: 'b',
- }),
- ],
- headers: {
- Link:
- '<http://127.0.0.1:8000/api/0/organizations/org-slug/projects/?cursor=1443575731:0:1>; rel="previous"; results="true"; cursor="1443575731:0:1", ' +
- '<http://127.0.0.1:8000/api/0/organizations/org-slug/projects/?cursor=1443575731:0:0>; rel="next"; results="true"; cursor="1443575731:0:0',
- },
- });
- ProjectsStore.loadInitialData([]);
- await tick();
- });
- it('fetches projects from API', async function() {
- const wrapper = createWrapper();
- // This is initial state
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: true,
- isIncomplete: null,
- hasMore: null,
- projects: [],
- })
- );
- await tick();
- wrapper.update();
- expect(request).toHaveBeenCalledWith(
- expect.anything(),
- expect.objectContaining({
- query: {},
- })
- );
- expect(renderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: false,
- isIncomplete: null,
- hasMore: true,
- projects: [
- expect.objectContaining({
- id: '100',
- slug: 'a',
- }),
- expect.objectContaining({
- id: '101',
- slug: 'b',
- }),
- ],
- })
- );
- });
- it('queries API for more projects and replaces results', async function() {
- const myRenderer = jest.fn(({onSearch}) => (
- <input onChange={({target}) => onSearch(target.value)} />
- ));
- const wrapper = createWrapper({children: myRenderer});
- // This is initial state
- expect(myRenderer).toHaveBeenCalledWith(
- expect.objectContaining({
- fetching: true,
- isIncomplete: null,
- hasMore: null,
- projects: [],
- })
- );
- await tick();
- wrapper.update();
- request.mockClear();
- request = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/projects/',
- body: [
- TestStubs.Project({
- id: '102',
- slug: 'test1',
- }),
- TestStubs.Project({
- id: '103',
- slug: 'test2',
- }),
- ],
- });
- wrapper.find('input').simulate('change', {target: {value: 'test'}});
- expect(request).toHaveBeenCalledWith(
- expect.anything(),
- expect.objectContaining({
- query: {
- query: 'test',
- },
- })
- );
- await tick();
- wrapper.update();
- expect(myRenderer).toHaveBeenLastCalledWith(
- expect.objectContaining({
- fetching: false,
- isIncomplete: null,
- hasMore: false,
- projects: [
- expect.objectContaining({
- id: '102',
- slug: 'test1',
- }),
- expect.objectContaining({
- id: '103',
- slug: 'test2',
- }),
- ],
- })
- );
- });
- it('queries API for more projects and appends results', async function() {
- const myRenderer = jest.fn(({onSearch}) => (
- <input onChange={({target}) => onSearch(target.value, {append: true})} />
- ));
- const wrapper = createWrapper({children: myRenderer});
- await tick();
- wrapper.update();
- request.mockClear();
- request = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/projects/',
- body: [
- TestStubs.Project({
- id: '102',
- slug: 'test1',
- }),
- TestStubs.Project({
- id: '103',
- slug: 'test2',
- }),
- ],
- });
- wrapper.find('input').simulate('change', {target: {value: 'test'}});
- expect(request).toHaveBeenCalledWith(
- expect.anything(),
- expect.objectContaining({
- query: {
- query: 'test',
- },
- })
- );
- await tick();
- wrapper.update();
- expect(myRenderer).toHaveBeenLastCalledWith(
- expect.objectContaining({
- fetching: false,
- isIncomplete: null,
- hasMore: false,
- projects: [
- expect.objectContaining({
- id: '100',
- slug: 'a',
- }),
- expect.objectContaining({
- id: '101',
- slug: 'b',
- }),
- expect.objectContaining({
- id: '102',
- slug: 'test1',
- }),
- expect.objectContaining({
- id: '103',
- slug: 'test2',
- }),
- ],
- })
- );
- // Should not have duplicates
- wrapper.find('input').simulate('change', {target: {value: 'test'}});
- await tick();
- wrapper.update();
- expect(myRenderer).toHaveBeenLastCalledWith(
- expect.objectContaining({
- projects: [
- expect.objectContaining({
- id: '100',
- slug: 'a',
- }),
- expect.objectContaining({
- id: '101',
- slug: 'b',
- }),
- expect.objectContaining({
- id: '102',
- slug: 'test1',
- }),
- expect.objectContaining({
- id: '103',
- slug: 'test2',
- }),
- ],
- })
- );
- });
- });
- });
|