Skip to content

Commit

Permalink
fix: fix Apollo client cache update error for Links field (twentyhq#5473
Browse files Browse the repository at this point in the history
  • Loading branch information
thaisguigon authored May 22, 2024
1 parent d1cbd70 commit 474dfd7
Show file tree
Hide file tree
Showing 8 changed files with 159 additions and 15 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
import { ObjectMetadataItem } from '@/object-metadata/types/ObjectMetadataItem';
import {
mockedObjectMetadataItems,
mockedPersonObjectMetadataItem,
} from '~/testing/mock-data/metadata';
import { mockedPeopleData } from '~/testing/mock-data/people';

import { getRecordNodeFromRecord } from '../getRecordNodeFromRecord';

describe('getRecordNodeFromRecord', () => {
it('computes relation records cache references by default', () => {
// Given
const objectMetadataItems: ObjectMetadataItem[] = mockedObjectMetadataItems;
const objectMetadataItem: Pick<
ObjectMetadataItem,
'fields' | 'namePlural' | 'nameSingular'
> = mockedPersonObjectMetadataItem;
const recordGqlFields = {
name: true,
company: true,
};
const record = mockedPeopleData[0];

// When
const result = getRecordNodeFromRecord({
objectMetadataItems,
objectMetadataItem,
recordGqlFields,
record,
});

// Then
expect(result).toEqual({
__typename: 'Person',
company: {
__ref: 'Company:5c21e19e-e049-4393-8c09-3e3f8fb09ecb',
},
name: {
__typename: 'FullName',
firstName: 'Alexandre',
lastName: 'Prot',
},
});
});

it('does not compute relation records cache references when `computeReferences` is false', () => {
// Given
const objectMetadataItems: ObjectMetadataItem[] = mockedObjectMetadataItems;
const objectMetadataItem: Pick<
ObjectMetadataItem,
'fields' | 'namePlural' | 'nameSingular'
> = mockedPersonObjectMetadataItem;
const recordGqlFields = {
name: true,
company: true,
};
const record = mockedPeopleData[0];
const computeReferences = false;

// When
const result = getRecordNodeFromRecord({
objectMetadataItems,
objectMetadataItem,
recordGqlFields,
record,
computeReferences,
});

// Then
expect(result).toEqual({
__typename: 'Person',
company: record.company,
name: {
__typename: 'FullName',
firstName: 'Alexandre',
lastName: 'Prot',
},
});
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import {
RelationDefinitionType,
} from '~/generated-metadata/graphql';
import { isDefined } from '~/utils/isDefined';
import { lowerAndCapitalize } from '~/utils/string/lowerAndCapitalize';
import { pascalCase } from '~/utils/string/pascalCase';

export const getRecordNodeFromRecord = <T extends ObjectRecord>({
objectMetadataItems,
Expand Down Expand Up @@ -129,14 +129,15 @@ export const getRecordNodeFromRecord = <T extends ObjectRecord>({
];
}
case FieldMetadataType.Link:
case FieldMetadataType.Links:
case FieldMetadataType.Address:
case FieldMetadataType.FullName:
case FieldMetadataType.Currency: {
return [
fieldName,
{
...value,
__typename: lowerAndCapitalize(field.type),
__typename: pascalCase(field.type),
},
];
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,11 +49,11 @@ export const responseData = {
personDuplicates: {
edges: [
{
node: { __typename: 'Person', ...mockedPeopleData[0], updatedAt: '' },
node: { ...mockedPeopleData[0], updatedAt: '' },
cursor: 'cursor1',
},
{
node: { __typename: 'Person', ...mockedPeopleData[1], updatedAt: '' },
node: { ...mockedPeopleData[1], updatedAt: '' },
cursor: 'cursor2',
},
],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ export const generateEmptyFieldValue = (
};
}
case FieldMetadataType.Links: {
return { primaryLinkUrl: '', primaryLinkLabel: '' };
return { primaryLinkUrl: '', primaryLinkLabel: '', secondaryLinks: null };
}
case FieldMetadataType.FullName: {
return {
Expand Down
11 changes: 10 additions & 1 deletion packages/twenty-front/src/testing/mock-data/people.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ type RequiredAndNotNull<T> = {
type MockedPerson = RequiredAndNotNull<
Pick<
Person,
| '__typename'
| 'id'
| 'name'
| 'linkedinLink'
Expand All @@ -20,12 +21,13 @@ type MockedPerson = RequiredAndNotNull<
| 'createdAt'
| 'companyId'
> & {
company: Pick<Company, 'id' | 'name' | 'domainName'>;
company: Pick<Company, '__typename' | 'id' | 'name' | 'domainName'>;
}
>;

export const mockedPeopleData: MockedPerson[] = [
{
__typename: 'Person',
id: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6b',
name: {
firstName: 'Alexandre',
Expand All @@ -45,6 +47,7 @@ export const mockedPeopleData: MockedPerson[] = [
jobTitle: 'CEO',
companyId: '5c21e19e-e049-4393-8c09-3e3f8fb09ecb',
company: {
__typename: 'Company',
id: '5c21e19e-e049-4393-8c09-3e3f8fb09ecb',
name: 'Qonto',
domainName: 'qonto.com',
Expand All @@ -54,6 +57,7 @@ export const mockedPeopleData: MockedPerson[] = [
city: 'Paris',
},
{
__typename: 'Person',
id: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6d',
name: { firstName: 'John', lastName: 'Doe' },
linkedinLink: {
Expand All @@ -69,6 +73,7 @@ export const mockedPeopleData: MockedPerson[] = [
email: '[email protected]',
companyId: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6e',
company: {
__typename: 'Company',
id: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6e',
name: 'LinkedIn',
domainName: 'linkedin.com',
Expand All @@ -78,6 +83,7 @@ export const mockedPeopleData: MockedPerson[] = [
city: 'Paris',
},
{
__typename: 'Person',
id: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6f',
name: {
firstName: 'Jane',
Expand All @@ -96,6 +102,7 @@ export const mockedPeopleData: MockedPerson[] = [
email: '[email protected]',
companyId: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6g',
company: {
__typename: 'Company',
id: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6g',
name: 'Sequoia',
domainName: 'sequoiacap.com',
Expand All @@ -105,6 +112,7 @@ export const mockedPeopleData: MockedPerson[] = [
city: 'Paris',
},
{
__typename: 'Person',
id: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6h',
name: {
firstName: 'Janice',
Expand All @@ -123,6 +131,7 @@ export const mockedPeopleData: MockedPerson[] = [
jobTitle: 'CEO',
companyId: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6i',
company: {
__typename: 'Company',
id: '7dfbc3f7-6e5e-4128-957e-8d86808cdf6i',
name: 'Facebook',
domainName: 'facebook.com',
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import { pascalCase } from '../pascalCase';

describe('pascalCase', () => {
it('converts a string to pascal case', () => {
// Given
const input = 'HELLO_WORLD';

// When
const result = pascalCase(input);

// Then
expect(result).toBe('HelloWorld');
});

it('handles empty strings', () => {
// Given
const input = '';

// When
const result = pascalCase(input);

// Then
expect(result).toBe('');
});

it('handles strings with only one word', () => {
// Given
const input = 'hello';

// When
const result = pascalCase(input);

// Then
expect(result).toBe('Hello');
});

it('handles strings with several words, spaces and special characters', () => {
// Given
const input = '& Hello world! How are you today? #';

// When
const result = pascalCase(input);

// Then
expect(result).toBe('HelloWorldHowAreYouToday');
});

it('handles strings with leading and trailing spaces', () => {
// Given
const input = ' hello_world ';

// When
const result = pascalCase(input);

// Then
expect(result).toBe('HelloWorld');
});
});
9 changes: 0 additions & 9 deletions packages/twenty-front/src/utils/string/lowerAndCapitalize.ts

This file was deleted.

5 changes: 5 additions & 0 deletions packages/twenty-front/src/utils/string/pascalCase.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import camelCase from 'lodash.camelcase';

import { capitalize } from '~/utils/string/capitalize';

export const pascalCase = (str: string) => capitalize(camelCase(str));

0 comments on commit 474dfd7

Please sign in to comment.