2021-01-03 14:25:43 +05:30
|
|
|
import { updateContainerExpirationPolicy } from '~/registry/settings/graphql/utils/cache_update';
|
2021-02-22 17:27:13 +05:30
|
|
|
import expirationPolicyQuery from '~/registry/settings/graphql/queries/get_expiration_policy.query.graphql';
|
2021-01-03 14:25:43 +05:30
|
|
|
|
|
|
|
describe('Registry settings cache update', () => {
|
|
|
|
let client;
|
|
|
|
|
|
|
|
const payload = {
|
|
|
|
data: {
|
|
|
|
updateContainerExpirationPolicy: {
|
|
|
|
containerExpirationPolicy: {
|
|
|
|
enabled: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const cacheMock = {
|
|
|
|
project: {
|
|
|
|
containerExpirationPolicy: {
|
|
|
|
enabled: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const queryAndVariables = {
|
|
|
|
query: expirationPolicyQuery,
|
|
|
|
variables: { projectPath: 'foo' },
|
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
client = {
|
|
|
|
readQuery: jest.fn().mockReturnValue(cacheMock),
|
|
|
|
writeQuery: jest.fn(),
|
|
|
|
};
|
|
|
|
});
|
|
|
|
describe('Registry settings cache update', () => {
|
|
|
|
it('calls readQuery', () => {
|
|
|
|
updateContainerExpirationPolicy('foo')(client, payload);
|
|
|
|
expect(client.readQuery).toHaveBeenCalledWith(queryAndVariables);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('writes the correct result in the cache', () => {
|
|
|
|
updateContainerExpirationPolicy('foo')(client, payload);
|
|
|
|
expect(client.writeQuery).toHaveBeenCalledWith({
|
|
|
|
...queryAndVariables,
|
|
|
|
data: {
|
|
|
|
project: {
|
|
|
|
containerExpirationPolicy: {
|
|
|
|
enabled: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|