| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786 |
- import { OnModuleInit } from '@nestjs/common';
- import { HistoryEntryType } from '@vendure/common/lib/generated-types';
- import { omit } from '@vendure/common/lib/omit';
- import { pick } from '@vendure/common/lib/pick';
- import {
- AccountRegistrationEvent,
- EventBus,
- EventBusModule,
- mergeConfig,
- VendurePlugin,
- } from '@vendure/core';
- import { createErrorResultGuard, createTestEnvironment, ErrorResultGuard } from '@vendure/testing';
- import gql from 'graphql-tag';
- import path from 'path';
- import { initialData } from '../../../e2e-common/e2e-initial-data';
- import { testConfig, TEST_SETUP_TIMEOUT_MS } from '../../../e2e-common/test-config';
- import { CUSTOMER_FRAGMENT } from './graphql/fragments';
- import {
- AddNoteToCustomer,
- CreateAddress,
- CreateAdministrator,
- CreateCustomer,
- CustomerFragment,
- DeleteCustomer,
- DeleteCustomerAddress,
- DeleteCustomerNote,
- DeletionResult,
- ErrorCode,
- GetCustomer,
- GetCustomerHistory,
- GetCustomerList,
- GetCustomerOrders,
- GetCustomerWithUser,
- Me,
- UpdateAddress,
- UpdateCustomer,
- UpdateCustomerNote,
- } from './graphql/generated-e2e-admin-types';
- import {
- ActiveOrderCustomerFragment,
- AddItemToOrder,
- AddItemToOrderMutation,
- AddItemToOrderMutationVariables,
- SetCustomerForOrderMutation,
- SetCustomerForOrderMutationVariables,
- UpdatedOrderFragment,
- } from './graphql/generated-e2e-shop-types';
- import {
- CREATE_ADDRESS,
- CREATE_ADMINISTRATOR,
- CREATE_CUSTOMER,
- DELETE_CUSTOMER,
- DELETE_CUSTOMER_NOTE,
- GET_CUSTOMER,
- GET_CUSTOMER_HISTORY,
- GET_CUSTOMER_LIST,
- ME,
- UPDATE_ADDRESS,
- UPDATE_CUSTOMER,
- UPDATE_CUSTOMER_NOTE,
- } from './graphql/shared-definitions';
- import { ADD_ITEM_TO_ORDER, SET_CUSTOMER } from './graphql/shop-definitions';
- import { assertThrowsWithMessage } from './utils/assert-throws-with-message';
- // tslint:disable:no-non-null-assertion
- let sendEmailFn: jest.Mock;
- /**
- * This mock plugin simulates an EmailPlugin which would send emails
- * on the registration & password reset events.
- */
- @VendurePlugin({
- imports: [EventBusModule],
- })
- class TestEmailPlugin implements OnModuleInit {
- constructor(private eventBus: EventBus) {}
- onModuleInit() {
- this.eventBus.ofType(AccountRegistrationEvent).subscribe(event => {
- sendEmailFn(event);
- });
- }
- }
- describe('Customer resolver', () => {
- const { server, adminClient, shopClient } = createTestEnvironment(
- mergeConfig(testConfig(), { plugins: [TestEmailPlugin] }),
- );
- let firstCustomer: GetCustomerList.Items;
- let secondCustomer: GetCustomerList.Items;
- let thirdCustomer: GetCustomerList.Items;
- const customerErrorGuard: ErrorResultGuard<CustomerFragment> = createErrorResultGuard(
- input => !!input.emailAddress,
- );
- beforeAll(async () => {
- await server.init({
- initialData,
- productsCsvPath: path.join(__dirname, 'fixtures/e2e-products-minimal.csv'),
- customerCount: 5,
- });
- await adminClient.asSuperAdmin();
- }, TEST_SETUP_TIMEOUT_MS);
- afterAll(async () => {
- await server.destroy();
- });
- it('customers list', async () => {
- const result = await adminClient.query<GetCustomerList.Query, GetCustomerList.Variables>(
- GET_CUSTOMER_LIST,
- );
- expect(result.customers.items.length).toBe(5);
- expect(result.customers.totalItems).toBe(5);
- firstCustomer = result.customers.items[0];
- secondCustomer = result.customers.items[1];
- thirdCustomer = result.customers.items[2];
- });
- it('customers list filter by postalCode', async () => {
- const result = await adminClient.query<GetCustomerList.Query, GetCustomerList.Variables>(
- GET_CUSTOMER_LIST,
- {
- options: {
- filter: {
- postalCode: {
- eq: 'NU9 0PW',
- },
- },
- },
- },
- );
- expect(result.customers.items.length).toBe(1);
- expect(result.customers.items[0].emailAddress).toBe('eliezer56@yahoo.com');
- });
- it('customer resolver resolves User', async () => {
- const emailAddress = 'same-email@test.com';
- // Create an administrator with the same email first in order to ensure the right user is resolved.
- // This test also validates that a customer can be created with the same identifier
- // of an existing administrator
- const { createAdministrator } = await adminClient.query<
- CreateAdministrator.Mutation,
- CreateAdministrator.Variables
- >(CREATE_ADMINISTRATOR, {
- input: {
- emailAddress,
- firstName: 'First',
- lastName: 'Last',
- password: '123',
- roleIds: ['1'],
- },
- });
- expect(createAdministrator.emailAddress).toEqual(emailAddress);
- const { createCustomer } = await adminClient.query<CreateCustomer.Mutation, CreateCustomer.Variables>(
- CREATE_CUSTOMER,
- {
- input: {
- emailAddress,
- firstName: 'New',
- lastName: 'Customer',
- },
- password: 'test',
- },
- );
- customerErrorGuard.assertSuccess(createCustomer);
- expect(createCustomer.emailAddress).toEqual(emailAddress);
- const { customer } = await adminClient.query<
- GetCustomerWithUser.Query,
- GetCustomerWithUser.Variables
- >(GET_CUSTOMER_WITH_USER, {
- id: createCustomer.id,
- });
- expect(customer!.user).toEqual({
- id: createCustomer.user?.id,
- identifier: emailAddress,
- verified: true,
- });
- });
- describe('addresses', () => {
- let firstCustomerAddressIds: string[] = [];
- let firstCustomerThirdAddressId: string;
- it(
- 'createCustomerAddress throws on invalid countryCode',
- assertThrowsWithMessage(
- () =>
- adminClient.query<CreateAddress.Mutation, CreateAddress.Variables>(CREATE_ADDRESS, {
- id: firstCustomer.id,
- input: {
- streetLine1: 'streetLine1',
- countryCode: 'INVALID',
- },
- }),
- `The countryCode "INVALID" was not recognized`,
- ),
- );
- it('createCustomerAddress creates a new address', async () => {
- const result = await adminClient.query<CreateAddress.Mutation, CreateAddress.Variables>(
- CREATE_ADDRESS,
- {
- id: firstCustomer.id,
- input: {
- fullName: 'fullName',
- company: 'company',
- streetLine1: 'streetLine1',
- streetLine2: 'streetLine2',
- city: 'city',
- province: 'province',
- postalCode: 'postalCode',
- countryCode: 'GB',
- phoneNumber: 'phoneNumber',
- defaultShippingAddress: false,
- defaultBillingAddress: false,
- },
- },
- );
- expect(omit(result.createCustomerAddress, ['id'])).toEqual({
- fullName: 'fullName',
- company: 'company',
- streetLine1: 'streetLine1',
- streetLine2: 'streetLine2',
- city: 'city',
- province: 'province',
- postalCode: 'postalCode',
- country: {
- code: 'GB',
- name: 'United Kingdom',
- },
- phoneNumber: 'phoneNumber',
- defaultShippingAddress: false,
- defaultBillingAddress: false,
- });
- });
- it('customer query returns addresses', async () => {
- const result = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(GET_CUSTOMER, {
- id: firstCustomer.id,
- });
- expect(result.customer!.addresses!.length).toBe(2);
- firstCustomerAddressIds = result.customer!.addresses!.map(a => a.id).sort();
- });
- it('updateCustomerAddress updates the country', async () => {
- const result = await adminClient.query<UpdateAddress.Mutation, UpdateAddress.Variables>(
- UPDATE_ADDRESS,
- {
- input: {
- id: firstCustomerAddressIds[0],
- countryCode: 'AT',
- },
- },
- );
- expect(result.updateCustomerAddress.country).toEqual({
- code: 'AT',
- name: 'Austria',
- });
- });
- it('updateCustomerAddress allows only a single default address', async () => {
- // set the first customer's second address to be default
- const result1 = await adminClient.query<UpdateAddress.Mutation, UpdateAddress.Variables>(
- UPDATE_ADDRESS,
- {
- input: {
- id: firstCustomerAddressIds[1],
- defaultShippingAddress: true,
- defaultBillingAddress: true,
- },
- },
- );
- expect(result1.updateCustomerAddress.defaultShippingAddress).toBe(true);
- expect(result1.updateCustomerAddress.defaultBillingAddress).toBe(true);
- // assert the first customer's other addresse is not default
- const result2 = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(GET_CUSTOMER, {
- id: firstCustomer.id,
- });
- const otherAddress = result2.customer!.addresses!.filter(
- a => a.id !== firstCustomerAddressIds[1],
- )[0]!;
- expect(otherAddress.defaultShippingAddress).toBe(false);
- expect(otherAddress.defaultBillingAddress).toBe(false);
- // set the first customer's first address to be default
- const result3 = await adminClient.query<UpdateAddress.Mutation, UpdateAddress.Variables>(
- UPDATE_ADDRESS,
- {
- input: {
- id: firstCustomerAddressIds[0],
- defaultShippingAddress: true,
- defaultBillingAddress: true,
- },
- },
- );
- expect(result3.updateCustomerAddress.defaultShippingAddress).toBe(true);
- expect(result3.updateCustomerAddress.defaultBillingAddress).toBe(true);
- // assert the first customer's second address is not default
- const result4 = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(GET_CUSTOMER, {
- id: firstCustomer.id,
- });
- const otherAddress2 = result4.customer!.addresses!.filter(
- a => a.id !== firstCustomerAddressIds[0],
- )[0]!;
- expect(otherAddress2.defaultShippingAddress).toBe(false);
- expect(otherAddress2.defaultBillingAddress).toBe(false);
- // get the second customer's address id
- const result5 = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(GET_CUSTOMER, {
- id: secondCustomer.id,
- });
- const secondCustomerAddressId = result5.customer!.addresses![0].id;
- // set the second customer's address to be default
- const result6 = await adminClient.query<UpdateAddress.Mutation, UpdateAddress.Variables>(
- UPDATE_ADDRESS,
- {
- input: {
- id: secondCustomerAddressId,
- defaultShippingAddress: true,
- defaultBillingAddress: true,
- },
- },
- );
- expect(result6.updateCustomerAddress.defaultShippingAddress).toBe(true);
- expect(result6.updateCustomerAddress.defaultBillingAddress).toBe(true);
- // assets the first customer's address defaults are unchanged
- const result7 = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(GET_CUSTOMER, {
- id: firstCustomer.id,
- });
- expect(result7.customer!.addresses![0].defaultShippingAddress).toBe(true);
- expect(result7.customer!.addresses![0].defaultBillingAddress).toBe(true);
- expect(result7.customer!.addresses![1].defaultShippingAddress).toBe(false);
- expect(result7.customer!.addresses![1].defaultBillingAddress).toBe(false);
- });
- it('createCustomerAddress with true defaults unsets existing defaults', async () => {
- const { createCustomerAddress } = await adminClient.query<
- CreateAddress.Mutation,
- CreateAddress.Variables
- >(CREATE_ADDRESS, {
- id: firstCustomer.id,
- input: {
- streetLine1: 'new default streetline',
- countryCode: 'GB',
- defaultShippingAddress: true,
- defaultBillingAddress: true,
- },
- });
- expect(omit(createCustomerAddress, ['id'])).toEqual({
- fullName: '',
- company: '',
- streetLine1: 'new default streetline',
- streetLine2: '',
- city: '',
- province: '',
- postalCode: '',
- country: {
- code: 'GB',
- name: 'United Kingdom',
- },
- phoneNumber: '',
- defaultShippingAddress: true,
- defaultBillingAddress: true,
- });
- const { customer } = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(
- GET_CUSTOMER,
- {
- id: firstCustomer.id,
- },
- );
- for (const address of customer!.addresses!) {
- const shouldBeDefault = address.id === createCustomerAddress.id;
- expect(address.defaultShippingAddress).toEqual(shouldBeDefault);
- expect(address.defaultBillingAddress).toEqual(shouldBeDefault);
- }
- firstCustomerThirdAddressId = createCustomerAddress.id;
- });
- it('deleteCustomerAddress on default address resets defaults', async () => {
- const { deleteCustomerAddress } = await adminClient.query<
- DeleteCustomerAddress.Mutation,
- DeleteCustomerAddress.Variables
- >(
- gql`
- mutation DeleteCustomerAddress($id: ID!) {
- deleteCustomerAddress(id: $id) {
- success
- }
- }
- `,
- { id: firstCustomerThirdAddressId },
- );
- expect(deleteCustomerAddress.success).toBe(true);
- const { customer } = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(
- GET_CUSTOMER,
- {
- id: firstCustomer.id,
- },
- );
- expect(customer!.addresses!.length).toBe(2);
- const defaultAddress = customer!.addresses!.filter(
- a => a.defaultBillingAddress && a.defaultShippingAddress,
- );
- const otherAddress = customer!.addresses!.filter(
- a => !a.defaultBillingAddress && !a.defaultShippingAddress,
- );
- expect(defaultAddress.length).toBe(1);
- expect(otherAddress.length).toBe(1);
- });
- });
- describe('orders', () => {
- const orderResultGuard: ErrorResultGuard<UpdatedOrderFragment> = createErrorResultGuard(
- input => !!input.lines,
- );
- it(`lists that user\'s orders`, async () => {
- // log in as first customer
- await shopClient.asUserWithCredentials(firstCustomer.emailAddress, 'test');
- // add an item to the order to create an order
- const { addItemToOrder } = await shopClient.query<
- AddItemToOrder.Mutation,
- AddItemToOrder.Variables
- >(ADD_ITEM_TO_ORDER, {
- productVariantId: 'T_1',
- quantity: 1,
- });
- orderResultGuard.assertSuccess(addItemToOrder);
- const { customer } = await adminClient.query<
- GetCustomerOrders.Query,
- GetCustomerOrders.Variables
- >(GET_CUSTOMER_ORDERS, { id: firstCustomer.id });
- expect(customer!.orders.totalItems).toBe(1);
- expect(customer!.orders.items[0].id).toBe(addItemToOrder!.id);
- });
- });
- describe('creation', () => {
- it('triggers verification event if no password supplied', async () => {
- sendEmailFn = jest.fn();
- const { createCustomer } = await adminClient.query<
- CreateCustomer.Mutation,
- CreateCustomer.Variables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress: 'test1@test.com',
- firstName: 'New',
- lastName: 'Customer',
- },
- });
- customerErrorGuard.assertSuccess(createCustomer);
- expect(createCustomer.user!.verified).toBe(false);
- expect(sendEmailFn).toHaveBeenCalledTimes(1);
- expect(sendEmailFn.mock.calls[0][0] instanceof AccountRegistrationEvent).toBe(true);
- expect(sendEmailFn.mock.calls[0][0].user.identifier).toBe('test1@test.com');
- });
- it('creates a verified Customer', async () => {
- sendEmailFn = jest.fn();
- const { createCustomer } = await adminClient.query<
- CreateCustomer.Mutation,
- CreateCustomer.Variables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress: 'test2@test.com',
- firstName: 'New',
- lastName: 'Customer',
- },
- password: 'test',
- });
- customerErrorGuard.assertSuccess(createCustomer);
- expect(createCustomer.user!.verified).toBe(true);
- expect(sendEmailFn).toHaveBeenCalledTimes(0);
- });
- it('return error result when using an existing, non-deleted emailAddress', async () => {
- const { createCustomer } = await adminClient.query<
- CreateCustomer.Mutation,
- CreateCustomer.Variables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress: 'test2@test.com',
- firstName: 'New',
- lastName: 'Customer',
- },
- password: 'test',
- });
- customerErrorGuard.assertErrorResult(createCustomer);
- expect(createCustomer.message).toBe('The email address is not available.');
- expect(createCustomer.errorCode).toBe(ErrorCode.EMAIL_ADDRESS_CONFLICT_ERROR);
- });
- });
- describe('update', () => {
- it('returns error result when emailAddress not available', async () => {
- const { updateCustomer } = await adminClient.query<
- UpdateCustomer.Mutation,
- UpdateCustomer.Variables
- >(UPDATE_CUSTOMER, {
- input: {
- id: thirdCustomer.id,
- emailAddress: firstCustomer.emailAddress,
- },
- });
- customerErrorGuard.assertErrorResult(updateCustomer);
- expect(updateCustomer.message).toBe('The email address is not available.');
- expect(updateCustomer.errorCode).toBe(ErrorCode.EMAIL_ADDRESS_CONFLICT_ERROR);
- });
- it('succeeds when emailAddress is available', async () => {
- const { updateCustomer } = await adminClient.query<
- UpdateCustomer.Mutation,
- UpdateCustomer.Variables
- >(UPDATE_CUSTOMER, {
- input: {
- id: thirdCustomer.id,
- emailAddress: 'unique-email@test.com',
- },
- });
- customerErrorGuard.assertSuccess(updateCustomer);
- expect(updateCustomer.emailAddress).toBe('unique-email@test.com');
- });
- // https://github.com/vendure-ecommerce/vendure/issues/1071
- it('updates the associated User email address', async () => {
- await shopClient.asUserWithCredentials('unique-email@test.com', 'test');
- const { me } = await shopClient.query<Me.Query>(ME);
- expect(me?.identifier).toBe('unique-email@test.com');
- });
- });
- describe('deletion', () => {
- it('deletes a customer', async () => {
- const result = await adminClient.query<DeleteCustomer.Mutation, DeleteCustomer.Variables>(
- DELETE_CUSTOMER,
- { id: thirdCustomer.id },
- );
- expect(result.deleteCustomer).toEqual({ result: DeletionResult.DELETED });
- });
- it('cannot get a deleted customer', async () => {
- const result = await adminClient.query<GetCustomer.Query, GetCustomer.Variables>(GET_CUSTOMER, {
- id: thirdCustomer.id,
- });
- expect(result.customer).toBe(null);
- });
- it('deleted customer omitted from list', async () => {
- const result = await adminClient.query<GetCustomerList.Query, GetCustomerList.Variables>(
- GET_CUSTOMER_LIST,
- );
- expect(result.customers.items.map(c => c.id).includes(thirdCustomer.id)).toBe(false);
- });
- it(
- 'updateCustomer throws for deleted customer',
- assertThrowsWithMessage(
- () =>
- adminClient.query<UpdateCustomer.Mutation, UpdateCustomer.Variables>(UPDATE_CUSTOMER, {
- input: {
- id: thirdCustomer.id,
- firstName: 'updated',
- },
- }),
- `No Customer with the id '3' could be found`,
- ),
- );
- it(
- 'createCustomerAddress throws for deleted customer',
- assertThrowsWithMessage(
- () =>
- adminClient.query<CreateAddress.Mutation, CreateAddress.Variables>(CREATE_ADDRESS, {
- id: thirdCustomer.id,
- input: {
- streetLine1: 'test',
- countryCode: 'GB',
- },
- }),
- `No Customer with the id '3' could be found`,
- ),
- );
- it('new Customer can be created with same emailAddress as a deleted Customer', async () => {
- const { createCustomer } = await adminClient.query<
- CreateCustomer.Mutation,
- CreateCustomer.Variables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress: thirdCustomer.emailAddress,
- firstName: 'Reusing Email',
- lastName: 'Customer',
- },
- });
- customerErrorGuard.assertSuccess(createCustomer);
- expect(createCustomer.emailAddress).toBe(thirdCustomer.emailAddress);
- expect(createCustomer.firstName).toBe('Reusing Email');
- expect(createCustomer.user?.identifier).toBe(thirdCustomer.emailAddress);
- });
- // https://github.com/vendure-ecommerce/vendure/issues/1960
- it('delete a guest Customer', async () => {
- const orderErrorGuard: ErrorResultGuard<ActiveOrderCustomerFragment> = createErrorResultGuard(
- input => !!input.lines,
- );
- await shopClient.asAnonymousUser();
- await shopClient.query<AddItemToOrderMutation, AddItemToOrderMutationVariables>(
- ADD_ITEM_TO_ORDER,
- {
- productVariantId: 'T_1',
- quantity: 1,
- },
- );
- const { setCustomerForOrder } = await shopClient.query<
- SetCustomerForOrderMutation,
- SetCustomerForOrderMutationVariables
- >(SET_CUSTOMER, {
- input: {
- firstName: 'Guest',
- lastName: 'Customer',
- emailAddress: 'guest@test.com',
- },
- });
- orderErrorGuard.assertSuccess(setCustomerForOrder);
- const result = await adminClient.query<DeleteCustomer.Mutation, DeleteCustomer.Variables>(
- DELETE_CUSTOMER,
- { id: setCustomerForOrder.customer!.id },
- );
- expect(result.deleteCustomer).toEqual({ result: DeletionResult.DELETED });
- });
- });
- describe('customer notes', () => {
- let noteId: string;
- it('addNoteToCustomer', async () => {
- const { addNoteToCustomer } = await adminClient.query<
- AddNoteToCustomer.Mutation,
- AddNoteToCustomer.Variables
- >(ADD_NOTE_TO_CUSTOMER, {
- input: {
- id: firstCustomer.id,
- isPublic: false,
- note: 'Test note',
- },
- });
- const { customer } = await adminClient.query<
- GetCustomerHistory.Query,
- GetCustomerHistory.Variables
- >(GET_CUSTOMER_HISTORY, {
- id: firstCustomer.id,
- options: {
- filter: {
- type: {
- eq: HistoryEntryType.CUSTOMER_NOTE,
- },
- },
- },
- });
- expect(customer?.history.items.map(pick(['type', 'data']))).toEqual([
- {
- type: HistoryEntryType.CUSTOMER_NOTE,
- data: {
- note: 'Test note',
- },
- },
- ]);
- noteId = customer?.history.items[0].id!;
- });
- it('update note', async () => {
- const { updateCustomerNote } = await adminClient.query<
- UpdateCustomerNote.Mutation,
- UpdateCustomerNote.Variables
- >(UPDATE_CUSTOMER_NOTE, {
- input: {
- noteId,
- note: 'An updated note',
- },
- });
- expect(updateCustomerNote.data).toEqual({
- note: 'An updated note',
- });
- });
- it('delete note', async () => {
- const { customer: before } = await adminClient.query<
- GetCustomerHistory.Query,
- GetCustomerHistory.Variables
- >(GET_CUSTOMER_HISTORY, { id: firstCustomer.id });
- const historyCount = before?.history.totalItems!;
- const { deleteCustomerNote } = await adminClient.query<
- DeleteCustomerNote.Mutation,
- DeleteCustomerNote.Variables
- >(DELETE_CUSTOMER_NOTE, {
- id: noteId,
- });
- expect(deleteCustomerNote.result).toBe(DeletionResult.DELETED);
- const { customer: after } = await adminClient.query<
- GetCustomerHistory.Query,
- GetCustomerHistory.Variables
- >(GET_CUSTOMER_HISTORY, { id: firstCustomer.id });
- expect(after?.history.totalItems).toBe(historyCount - 1);
- });
- });
- });
- const GET_CUSTOMER_WITH_USER = gql`
- query GetCustomerWithUser($id: ID!) {
- customer(id: $id) {
- id
- user {
- id
- identifier
- verified
- }
- }
- }
- `;
- const GET_CUSTOMER_ORDERS = gql`
- query GetCustomerOrders($id: ID!) {
- customer(id: $id) {
- orders {
- items {
- id
- }
- totalItems
- }
- }
- }
- `;
- const ADD_NOTE_TO_CUSTOMER = gql`
- mutation AddNoteToCustomer($input: AddNoteToCustomerInput!) {
- addNoteToCustomer(input: $input) {
- ...Customer
- }
- }
- ${CUSTOMER_FRAGMENT}
- `;
|