| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849 |
- 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 } from '@vendure/core';
- import { createErrorResultGuard, createTestEnvironment, ErrorResultGuard } from '@vendure/testing';
- import gql from 'graphql-tag';
- import path from 'path';
- import { afterAll, beforeAll, describe, expect, it, vi } from 'vitest';
- import { initialData } from '../../../e2e-common/e2e-initial-data';
- import { TEST_SETUP_TIMEOUT_MS, testConfig } from '../../../e2e-common/test-config';
- import { CUSTOMER_FRAGMENT } from './graphql/fragments';
- import * as Codegen from './graphql/generated-e2e-admin-types';
- import { DeletionResult, ErrorCode } from './graphql/generated-e2e-admin-types';
- import {
- ActiveOrderCustomerFragment,
- 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';
- /* eslint-disable @typescript-eslint/no-non-null-assertion */
- type CustomerListItem = Codegen.GetCustomerListQuery['customers']['items'][number];
- describe('Customer resolver', () => {
- const { server, adminClient, shopClient } = createTestEnvironment(testConfig());
- let firstCustomer: CustomerListItem;
- let secondCustomer: CustomerListItem;
- let thirdCustomer: CustomerListItem;
- const customerErrorGuard: ErrorResultGuard<Codegen.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<
- Codegen.GetCustomerListQuery,
- Codegen.GetCustomerListQueryVariables
- >(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<
- Codegen.GetCustomerListQuery,
- Codegen.GetCustomerListQueryVariables
- >(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<
- Codegen.CreateAdministratorMutation,
- Codegen.CreateAdministratorMutationVariables
- >(CREATE_ADMINISTRATOR, {
- input: {
- emailAddress,
- firstName: 'First',
- lastName: 'Last',
- password: '123',
- roleIds: ['1'],
- },
- });
- expect(createAdministrator.emailAddress).toEqual(emailAddress);
- const { createCustomer } = await adminClient.query<
- Codegen.CreateCustomerMutation,
- Codegen.CreateCustomerMutationVariables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress,
- firstName: 'New',
- lastName: 'Customer',
- },
- password: 'test',
- });
- customerErrorGuard.assertSuccess(createCustomer);
- expect(createCustomer.emailAddress).toEqual(emailAddress);
- const { customer } = await adminClient.query<
- Codegen.GetCustomerWithUserQuery,
- Codegen.GetCustomerWithUserQueryVariables
- >(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<Codegen.CreateAddressMutation, Codegen.CreateAddressMutationVariables>(
- 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<
- Codegen.CreateAddressMutation,
- Codegen.CreateAddressMutationVariables
- >(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<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(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<
- Codegen.UpdateAddressMutation,
- Codegen.UpdateAddressMutationVariables
- >(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<
- Codegen.UpdateAddressMutation,
- Codegen.UpdateAddressMutationVariables
- >(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 address is not default
- const result2 = await adminClient.query<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(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<
- Codegen.UpdateAddressMutation,
- Codegen.UpdateAddressMutationVariables
- >(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<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(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<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(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<
- Codegen.UpdateAddressMutation,
- Codegen.UpdateAddressMutationVariables
- >(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<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(GET_CUSTOMER, {
- id: firstCustomer.id,
- });
- const firstCustomerFirstAddress = result7.customer!.addresses!.find(
- a => a.id === firstCustomerAddressIds[0],
- )!;
- const firstCustomerSecondAddress = result7.customer!.addresses!.find(
- a => a.id === firstCustomerAddressIds[1],
- )!;
- expect(firstCustomerFirstAddress.defaultShippingAddress).toBe(true);
- expect(firstCustomerFirstAddress.defaultBillingAddress).toBe(true);
- expect(firstCustomerSecondAddress.defaultShippingAddress).toBe(false);
- expect(firstCustomerSecondAddress.defaultBillingAddress).toBe(false);
- });
- it('createCustomerAddress with true defaults unsets existing defaults', async () => {
- const { createCustomerAddress } = await adminClient.query<
- Codegen.CreateAddressMutation,
- Codegen.CreateAddressMutationVariables
- >(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<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(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<
- Codegen.DeleteCustomerAddressMutation,
- Codegen.DeleteCustomerAddressMutationVariables
- >(
- gql`
- mutation DeleteCustomerAddress($id: ID!) {
- deleteCustomerAddress(id: $id) {
- success
- }
- }
- `,
- { id: firstCustomerThirdAddressId },
- );
- expect(deleteCustomerAddress.success).toBe(true);
- const { customer } = await adminClient.query<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(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<
- AddItemToOrderMutation,
- AddItemToOrderMutationVariables
- >(ADD_ITEM_TO_ORDER, {
- productVariantId: 'T_1',
- quantity: 1,
- });
- orderResultGuard.assertSuccess(addItemToOrder);
- const { customer } = await adminClient.query<
- Codegen.GetCustomerOrdersQuery,
- Codegen.GetCustomerOrdersQueryVariables
- >(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 () => {
- const sendEmailFn = vi.fn();
- let resolveFn: () => void;
- const subscription = server.app
- .get(EventBus)
- .ofType(AccountRegistrationEvent)
- .subscribe(event => {
- sendEmailFn(event);
- resolveFn?.();
- });
- const eventReceived = new Promise<void>(resolve => {
- resolveFn = resolve;
- });
- const { createCustomer } = await adminClient.query<
- Codegen.CreateCustomerMutation,
- Codegen.CreateCustomerMutationVariables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress: 'test1@test.com',
- firstName: 'New',
- lastName: 'Customer',
- },
- });
- customerErrorGuard.assertSuccess(createCustomer);
- expect(createCustomer.user!.verified).toBe(false);
- // Wait for the event to be received before making assertions
- await eventReceived;
- 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');
- subscription.unsubscribe();
- });
- it('creates a verified Customer', async () => {
- const sendEmailFn = vi.fn();
- let resolveFn: () => void;
- const subscription = server.app
- .get(EventBus)
- .ofType(AccountRegistrationEvent)
- .subscribe(event => {
- sendEmailFn(event);
- resolveFn?.();
- });
- const eventReceived = new Promise<void>(resolve => {
- resolveFn = resolve;
- });
- const { createCustomer } = await adminClient.query<
- Codegen.CreateCustomerMutation,
- Codegen.CreateCustomerMutationVariables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress: 'test2@test.com',
- firstName: 'New',
- lastName: 'Customer',
- },
- password: 'test',
- });
- customerErrorGuard.assertSuccess(createCustomer);
- // Wait for the event to be received before making assertions
- await eventReceived;
- expect(createCustomer.user!.verified).toBe(true);
- expect(sendEmailFn).toHaveBeenCalledTimes(1);
- subscription.unsubscribe();
- });
- it('return error result when using an existing, non-deleted emailAddress', async () => {
- const { createCustomer } = await adminClient.query<
- Codegen.CreateCustomerMutation,
- Codegen.CreateCustomerMutationVariables
- >(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);
- });
- it('normalizes email address on creation', async () => {
- const { createCustomer } = await adminClient.query<
- Codegen.CreateCustomerMutation,
- Codegen.CreateCustomerMutationVariables
- >(CREATE_CUSTOMER, {
- input: {
- emailAddress: ' JoeSmith@test.com ',
- firstName: 'Joe',
- lastName: 'Smith',
- },
- password: 'test',
- });
- customerErrorGuard.assertSuccess(createCustomer);
- expect(createCustomer.emailAddress).toBe('joesmith@test.com');
- });
- });
- describe('update', () => {
- it('returns error result when emailAddress not available', async () => {
- const { updateCustomer } = await adminClient.query<
- Codegen.UpdateCustomerMutation,
- Codegen.UpdateCustomerMutationVariables
- >(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<
- Codegen.UpdateCustomerMutation,
- Codegen.UpdateCustomerMutationVariables
- >(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/vendurehq/vendure/issues/1071
- it('updates the associated User email address', async () => {
- await shopClient.asUserWithCredentials('unique-email@test.com', 'test');
- const { me } = await shopClient.query<Codegen.MeQuery>(ME);
- expect(me?.identifier).toBe('unique-email@test.com');
- });
- // https://github.com/vendurehq/vendure/issues/2449
- it('normalizes email address on update', async () => {
- const { updateCustomer } = await adminClient.query<
- Codegen.UpdateCustomerMutation,
- Codegen.UpdateCustomerMutationVariables
- >(UPDATE_CUSTOMER, {
- input: {
- id: thirdCustomer.id,
- emailAddress: ' Another-Address@test.com ',
- },
- });
- customerErrorGuard.assertSuccess(updateCustomer);
- expect(updateCustomer.emailAddress).toBe('another-address@test.com');
- await shopClient.asUserWithCredentials('another-address@test.com', 'test');
- const { me } = await shopClient.query<Codegen.MeQuery>(ME);
- expect(me?.identifier).toBe('another-address@test.com');
- });
- });
- describe('deletion', () => {
- it('deletes a customer', async () => {
- const result = await adminClient.query<
- Codegen.DeleteCustomerMutation,
- Codegen.DeleteCustomerMutationVariables
- >(DELETE_CUSTOMER, { id: thirdCustomer.id });
- expect(result.deleteCustomer).toEqual({ result: DeletionResult.DELETED });
- });
- it('cannot get a deleted customer', async () => {
- const result = await adminClient.query<
- Codegen.GetCustomerQuery,
- Codegen.GetCustomerQueryVariables
- >(GET_CUSTOMER, {
- id: thirdCustomer.id,
- });
- expect(result.customer).toBe(null);
- });
- it('deleted customer omitted from list', async () => {
- const result = await adminClient.query<
- Codegen.GetCustomerListQuery,
- Codegen.GetCustomerListQueryVariables
- >(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<
- Codegen.UpdateCustomerMutation,
- Codegen.UpdateCustomerMutationVariables
- >(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<Codegen.CreateAddressMutation, Codegen.CreateAddressMutationVariables>(
- 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<
- Codegen.CreateCustomerMutation,
- Codegen.CreateCustomerMutationVariables
- >(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/vendurehq/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<
- Codegen.DeleteCustomerMutation,
- Codegen.DeleteCustomerMutationVariables
- >(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<
- Codegen.AddNoteToCustomerMutation,
- Codegen.AddNoteToCustomerMutationVariables
- >(ADD_NOTE_TO_CUSTOMER, {
- input: {
- id: firstCustomer.id,
- isPublic: false,
- note: 'Test note',
- },
- });
- const { customer } = await adminClient.query<
- Codegen.GetCustomerHistoryQuery,
- Codegen.GetCustomerHistoryQueryVariables
- >(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<
- Codegen.UpdateCustomerNoteMutation,
- Codegen.UpdateCustomerNoteMutationVariables
- >(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<
- Codegen.GetCustomerHistoryQuery,
- Codegen.GetCustomerHistoryQueryVariables
- >(GET_CUSTOMER_HISTORY, { id: firstCustomer.id });
- const historyCount = before!.history.totalItems;
- const { deleteCustomerNote } = await adminClient.query<
- Codegen.DeleteCustomerNoteMutation,
- Codegen.DeleteCustomerNoteMutationVariables
- >(DELETE_CUSTOMER_NOTE, {
- id: noteId,
- });
- expect(deleteCustomerNote.result).toBe(DeletionResult.DELETED);
- const { customer: after } = await adminClient.query<
- Codegen.GetCustomerHistoryQuery,
- Codegen.GetCustomerHistoryQueryVariables
- >(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}
- `;
|