2022-11-10 08:56:36 -08:00
|
|
|
import { useEffect } from 'react';
|
|
|
|
|
|
|
|
import { __stub } from 'soapbox/api';
|
2023-05-02 16:49:13 -07:00
|
|
|
import { buildRelationship } from 'soapbox/jest/factory';
|
2022-11-10 08:56:36 -08:00
|
|
|
import { createTestStore, queryClient, renderHook, rootState, waitFor } from 'soapbox/jest/test-helpers';
|
|
|
|
import { Store } from 'soapbox/store';
|
|
|
|
|
|
|
|
import { useFetchRelationships } from '../relationships';
|
|
|
|
|
|
|
|
describe('useFetchRelationships()', () => {
|
|
|
|
let store: Store;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
const state = rootState;
|
|
|
|
store = createTestStore(state);
|
|
|
|
|
|
|
|
queryClient.clear();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with a successful query', () => {
|
|
|
|
describe('with one relationship', () => {
|
|
|
|
const id = '123';
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
__stub((mock) => {
|
|
|
|
mock
|
|
|
|
.onGet(`/api/v1/accounts/relationships?id[]=${id}`)
|
2023-05-02 16:49:13 -07:00
|
|
|
.reply(200, [buildRelationship({ id, blocked_by: true })]);
|
2022-11-10 08:56:36 -08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('is successful', async() => {
|
2023-01-05 16:05:55 -08:00
|
|
|
renderHook(() => {
|
2022-11-10 08:56:36 -08:00
|
|
|
const fetchRelationships = useFetchRelationships();
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
fetchRelationships.mutate({ accountIds: [id] });
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
return fetchRelationships;
|
|
|
|
}, undefined, store);
|
|
|
|
|
2023-01-05 16:05:55 -08:00
|
|
|
await waitFor(() => {
|
|
|
|
expect(store.getState().relationships.size).toBe(1);
|
|
|
|
expect(store.getState().relationships.getIn([id, 'id'])).toBe(id);
|
|
|
|
expect(store.getState().relationships.getIn([id, 'blocked_by'])).toBe(true);
|
|
|
|
});
|
2022-11-10 08:56:36 -08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with multiple relationships', () => {
|
|
|
|
const ids = ['123', '456'];
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
__stub((mock) => {
|
|
|
|
mock
|
|
|
|
.onGet(`/api/v1/accounts/relationships?id[]=${ids[0]}&id[]=${ids[1]}`)
|
2023-05-02 16:49:13 -07:00
|
|
|
.reply(200, ids.map((id) => buildRelationship({ id, blocked_by: true })));
|
2022-11-10 08:56:36 -08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('is successful', async() => {
|
2023-01-05 16:05:55 -08:00
|
|
|
renderHook(() => {
|
2022-11-10 08:56:36 -08:00
|
|
|
const fetchRelationships = useFetchRelationships();
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
fetchRelationships.mutate({ accountIds: ids });
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
return fetchRelationships;
|
|
|
|
}, undefined, store);
|
|
|
|
|
2023-01-05 16:05:55 -08:00
|
|
|
await waitFor(() => {
|
|
|
|
expect(store.getState().relationships.size).toBe(2);
|
|
|
|
expect(store.getState().relationships.getIn([ids[0], 'id'])).toBe(ids[0]);
|
|
|
|
expect(store.getState().relationships.getIn([ids[1], 'id'])).toBe(ids[1]);
|
|
|
|
});
|
2022-11-10 08:56:36 -08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with an unsuccessful query', () => {
|
|
|
|
const id = '123';
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
__stub((mock) => {
|
|
|
|
mock.onGet(`/api/v1/accounts/relationships?id[]=${id}`).networkError();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('is successful', async() => {
|
|
|
|
const { result } = renderHook(() => {
|
|
|
|
const fetchRelationships = useFetchRelationships();
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
fetchRelationships.mutate({ accountIds: [id] });
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
return fetchRelationships;
|
|
|
|
}, undefined, store);
|
|
|
|
|
|
|
|
await waitFor(() => expect(result.current.isLoading).toBe(false));
|
|
|
|
|
|
|
|
expect(result.current.error).toBeDefined();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|