Skip to content

Commit

Permalink
fix(db-postgres): joins with versions and hasMany relationship (paylo…
Browse files Browse the repository at this point in the history
…adcms#9370)

Fixes errors when having joins with versions +drafts on `hasMany: true`
relationships.
Removes `joinQuery` overhead if we don't need it for the current
operation. Right now, in all adapters we support joins only for `find`,
`findOne`, and `queryDrafts`.


Fixes payloadcms#9369
  • Loading branch information
r1tsuu authored Nov 21, 2024
1 parent 3d0424b commit d499de1
Show file tree
Hide file tree
Showing 11 changed files with 60 additions and 11 deletions.
1 change: 1 addition & 0 deletions packages/drizzle/src/deleteMany.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export const deleteMany: DeleteMany = async function deleteMany(
const result = await findMany({
adapter: this,
fields: collectionConfig.fields,
joins: false,
limit: 0,
locale: req.locale,
page: 1,
Expand Down
12 changes: 3 additions & 9 deletions packages/drizzle/src/deleteOne.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,7 @@ import { transform } from './transform/read/index.js'

export const deleteOne: DeleteOne = async function deleteOne(
this: DrizzleAdapter,
{
collection: collectionSlug,
joins: joinQuery,
req = {} as PayloadRequest,
select,
where: whereArg,
},
{ collection: collectionSlug, req = {} as PayloadRequest, select, where: whereArg },
) {
const db = this.sessions[await req?.transactionID]?.db || this.drizzle
const collection = this.payload.collections[collectionSlug].config
Expand Down Expand Up @@ -54,7 +48,7 @@ export const deleteOne: DeleteOne = async function deleteOne(
adapter: this,
depth: 0,
fields: collection.fields,
joinQuery,
joinQuery: false,
select,
tableName,
})
Expand All @@ -69,7 +63,7 @@ export const deleteOne: DeleteOne = async function deleteOne(
config: this.payload.config,
data: docToDelete,
fields: collection.fields,
joinQuery,
joinQuery: false,
})

await this.deleteWhere({
Expand Down
1 change: 1 addition & 0 deletions packages/drizzle/src/deleteVersions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ export const deleteVersions: DeleteVersions = async function deleteVersion(
const { docs } = await findMany({
adapter: this,
fields,
joins: false,
limit: 0,
locale,
page: 1,
Expand Down
2 changes: 1 addition & 1 deletion packages/drizzle/src/find/traverseFields.ts
Original file line number Diff line number Diff line change
Expand Up @@ -330,7 +330,6 @@ export const traverseFields = ({
}

case 'group':

case 'tab': {
const fieldSelect = select?.[field.name]

Expand Down Expand Up @@ -364,6 +363,7 @@ export const traverseFields = ({

break
}

case 'join': {
// when `joinsQuery` is false, do not join
if (joinQuery === false) {
Expand Down
1 change: 1 addition & 0 deletions packages/drizzle/src/findVersions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ export const findVersions: FindVersions = async function findVersions(
return findMany({
adapter: this,
fields,
joins: false,
limit,
locale,
page,
Expand Down
1 change: 1 addition & 0 deletions packages/drizzle/src/updateVersion.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ export async function updateVersion<T extends TypeWithID>(
data: versionData,
db,
fields,
joinQuery: false,
operation: 'update',
req,
select,
Expand Down
2 changes: 2 additions & 0 deletions packages/drizzle/src/upsertRow/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -411,6 +411,8 @@ export const upsertRow = async <T extends Record<string, unknown> | TypeWithID>(
// RETRIEVE NEWLY UPDATED ROW
// //////////////////////////////////

joinQuery = operation === 'create' ? false : joinQuery

const findManyArgs = buildFindManyArgs({
adapter,
depth: 0,
Expand Down
6 changes: 6 additions & 0 deletions test/joins/collections/CategoriesVersions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,12 @@ export const CategoriesVersions: CollectionConfig = {
collection: versionsSlug,
on: 'categoryVersion',
},
{
name: 'relatedVersionsMany',
type: 'join',
collection: versionsSlug,
on: 'categoryVersions',
},
],
versions: {
drafts: true,
Expand Down
6 changes: 6 additions & 0 deletions test/joins/collections/Versions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,12 @@ export const Versions: CollectionConfig = {
relationTo: 'categories-versions',
type: 'relationship',
},
{
name: 'categoryVersions',
relationTo: 'categories-versions',
type: 'relationship',
hasMany: true,
},
],
versions: {
drafts: true,
Expand Down
31 changes: 30 additions & 1 deletion test/joins/int.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -480,7 +480,20 @@ describe('Joins Field', () => {
expect(res.docs[0].relatedVersions.docs[0].id).toBe(version.id)
})

it('should populate joins when versions on both sides draft true payload.db.queryDrafts', async () => {
it('should populate joins with hasMany relationships when versions on both sides draft false', async () => {
const category = await payload.create({ collection: 'categories-versions', data: {} })

const version = await payload.create({
collection: 'versions',
data: { categoryVersions: [category.id] },
})

const res = await payload.find({ collection: 'categories-versions', draft: false })

expect(res.docs[0].relatedVersionsMany.docs[0].id).toBe(version.id)
})

it('should populate joins with hasMany relationships when versions on both sides draft true payload.db.queryDrafts', async () => {
const category = await payload.create({ collection: 'categories-versions', data: {} })

const version = await payload.create({
Expand All @@ -495,6 +508,22 @@ describe('Joins Field', () => {

expect(res.docs[0].relatedVersions.docs[0].id).toBe(version.id)
})

it('should populate joins when versions on both sides draft true payload.db.queryDrafts', async () => {
const category = await payload.create({ collection: 'categories-versions', data: {} })

const version = await payload.create({
collection: 'versions',
data: { categoryVersions: [category.id] },
})

const res = await payload.find({
collection: 'categories-versions',
draft: true,
})

expect(res.docs[0].relatedVersionsMany.docs[0].id).toBe(version.id)
})
})

describe('REST', () => {
Expand Down
8 changes: 8 additions & 0 deletions test/joins/payload-types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ export interface Config {
};
'categories-versions': {
relatedVersions: 'versions';
relatedVersionsMany: 'versions';
};
'localized-categories': {
relatedPosts: 'localized-posts';
Expand Down Expand Up @@ -197,6 +198,7 @@ export interface Version {
id: string;
category?: (string | null) | Category;
categoryVersion?: (string | null) | CategoriesVersion;
categoryVersions?: (string | CategoriesVersion)[] | null;
updatedAt: string;
createdAt: string;
_status?: ('draft' | 'published') | null;
Expand All @@ -211,6 +213,10 @@ export interface CategoriesVersion {
docs?: (string | Version)[] | null;
hasNextPage?: boolean | null;
} | null;
relatedVersionsMany?: {
docs?: (string | Version)[] | null;
hasNextPage?: boolean | null;
} | null;
updatedAt: string;
createdAt: string;
_status?: ('draft' | 'published') | null;
Expand Down Expand Up @@ -442,6 +448,7 @@ export interface UploadsSelect<T extends boolean = true> {
export interface VersionsSelect<T extends boolean = true> {
category?: T;
categoryVersion?: T;
categoryVersions?: T;
updatedAt?: T;
createdAt?: T;
_status?: T;
Expand All @@ -452,6 +459,7 @@ export interface VersionsSelect<T extends boolean = true> {
*/
export interface CategoriesVersionsSelect<T extends boolean = true> {
relatedVersions?: T;
relatedVersionsMany?: T;
updatedAt?: T;
createdAt?: T;
_status?: T;
Expand Down

0 comments on commit d499de1

Please sign in to comment.