| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594 |
- /* eslint-disable no-unused-vars */
- const mongoose = require('mongoose');
- const { getInstance } = require('../setup-crowi');
- let testUser1;
- let testUser2;
- let parentTag;
- let childTag;
- let parentForRename1;
- let parentForRename2;
- let parentForRename3;
- let parentForRename4;
- let childForRename1;
- let childForRename2;
- let childForRename3;
- let parentForDuplicate;
- let parentForDelete1;
- let parentForDelete2;
- let parentForDeleteCompletely;
- let parentForRevert1;
- let parentForRevert2;
- let childForDuplicate;
- let childForDelete;
- let childForDeleteCompletely;
- let childForRevert;
- describe('PageService', () => {
- let crowi;
- let Page;
- let Revision;
- let User;
- let Tag;
- let PageTagRelation;
- let xssSpy;
- beforeAll(async(done) => {
- crowi = await getInstance();
- User = mongoose.model('User');
- Page = mongoose.model('Page');
- Revision = mongoose.model('Revision');
- Tag = mongoose.model('Tag');
- PageTagRelation = mongoose.model('PageTagRelation');
- await User.insertMany([
- { name: 'someone1', username: 'someone1', email: 'someone1@example.com' },
- { name: 'someone2', username: 'someone2', email: 'someone2@example.com' },
- ]);
- testUser1 = await User.findOne({ username: 'someone1' });
- testUser2 = await User.findOne({ username: 'someone2' });
- await Page.insertMany([
- {
- path: '/parentForRename1',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForRename2',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForRename3',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForRename4',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForRename1/child',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForRename2/child',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForRename3/child',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForDuplicate',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- revision: '600d395667536503354cbe91',
- },
- {
- path: '/parentForDuplicate/child',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForDelete1',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForDelete2',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForDelete/child',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForDeleteCompletely',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/parentForDeleteCompletely/child',
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/trash/parentForRevert1',
- status: Page.STATUS_DELETED,
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/trash/parentForRevert2',
- status: Page.STATUS_DELETED,
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- {
- path: '/trash/parentForRevert/child',
- status: Page.STATUS_DELETED,
- grant: Page.GRANT_PUBLIC,
- creator: testUser1,
- lastUpdateUser: testUser1,
- },
- ]);
- parentForRename1 = await Page.findOne({ path: '/parentForRename1' });
- parentForRename2 = await Page.findOne({ path: '/parentForRename2' });
- parentForRename3 = await Page.findOne({ path: '/parentForRename3' });
- parentForRename4 = await Page.findOne({ path: '/parentForRename4' });
- parentForDuplicate = await Page.findOne({ path: '/parentForDuplicate' });
- parentForDelete1 = await Page.findOne({ path: '/parentForDelete1' });
- parentForDelete2 = await Page.findOne({ path: '/parentForDelete2' });
- parentForDeleteCompletely = await Page.findOne({ path: '/parentForDeleteCompletely' });
- parentForRevert1 = await Page.findOne({ path: '/trash/parentForRevert1' });
- parentForRevert2 = await Page.findOne({ path: '/trash/parentForRevert2' });
- childForRename1 = await Page.findOne({ path: '/parentForRename1/child' });
- childForRename2 = await Page.findOne({ path: '/parentForRename2/child' });
- childForRename3 = await Page.findOne({ path: '/parentForRename3/child' });
- childForDuplicate = await Page.findOne({ path: '/parentForDuplicate/child' });
- childForDelete = await Page.findOne({ path: '/parentForDelete/child' });
- childForDeleteCompletely = await Page.findOne({ path: '/parentForDeleteCompletely/child' });
- childForRevert = await Page.findOne({ path: '/trash/parentForRevert/child' });
- await Tag.insertMany([
- { name: 'Parent' },
- { name: 'Child' },
- ]);
- parentTag = await Tag.findOne({ name: 'Parent' });
- childTag = await Tag.findOne({ name: 'Child' });
- await PageTagRelation.insertMany([
- { relatedPage: parentForDuplicate, relatedTag: parentTag },
- { relatedPage: childForDuplicate, relatedTag: childTag },
- ]);
- await Revision.insertMany([
- {
- _id: '600d395667536503354cbe91',
- path: parentForDuplicate,
- body: 'duplicateBody',
- },
- ]);
- xssSpy = jest.spyOn(crowi.xss, 'process').mockImplementation(path => path);
- done();
- });
- describe('rename page', () => {
- let pageEventSpy;
- let renameDescendantsWithStreamSpy;
- const dateToUse = new Date('2000-01-01');
- const socketClientId = null;
- beforeEach(async(done) => {
- jest.spyOn(global.Date, 'now').mockImplementation(() => dateToUse);
- pageEventSpy = jest.spyOn(crowi.pageService.pageEvent, 'emit').mockImplementation();
- renameDescendantsWithStreamSpy = jest.spyOn(crowi.pageService, 'renameDescendantsWithStream').mockImplementation();
- done();
- });
- describe('renamePage()', () => {
- test('rename page without options', async() => {
- const resultPage = await crowi.pageService.renamePage(parentForRename1, '/renamed1', testUser2, {});
- const redirectedFromPage = await Page.findOne({ path: '/parentForRename1' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForRename1' });
- expect(xssSpy).toHaveBeenCalled();
- expect(renameDescendantsWithStreamSpy).not.toHaveBeenCalled();
- expect(pageEventSpy).toHaveBeenCalledWith('delete', parentForRename1, testUser2, socketClientId);
- expect(pageEventSpy).toHaveBeenCalledWith('create', resultPage, testUser2, socketClientId);
- expect(resultPage.path).toBe('/renamed1');
- expect(resultPage.updatedAt).toEqual(parentForRename1.updatedAt);
- expect(resultPage.lastUpdateUser).toEqual(testUser1._id);
- expect(redirectedFromPage).toBeNull();
- expect(redirectedFromPageRevision).toBeNull();
- });
- test('rename page with updateMetadata option', async() => {
- const resultPage = await crowi.pageService.renamePage(parentForRename2, '/renamed2', testUser2, { updateMetadata: true });
- const redirectedFromPage = await Page.findOne({ path: '/parentForRename2' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForRename2' });
- expect(xssSpy).toHaveBeenCalled();
- expect(renameDescendantsWithStreamSpy).not.toHaveBeenCalled();
- expect(pageEventSpy).toHaveBeenCalledWith('delete', parentForRename2, testUser2, socketClientId);
- expect(pageEventSpy).toHaveBeenCalledWith('create', resultPage, testUser2, socketClientId);
- expect(resultPage.path).toBe('/renamed2');
- expect(resultPage.updatedAt).toEqual(dateToUse);
- expect(resultPage.lastUpdateUser).toEqual(testUser2._id);
- expect(redirectedFromPage).toBeNull();
- expect(redirectedFromPageRevision).toBeNull();
- });
- test('rename page with createRedirectPage option', async() => {
- const resultPage = await crowi.pageService.renamePage(parentForRename3, '/renamed3', testUser2, { createRedirectPage: true });
- const redirectedFromPage = await Page.findOne({ path: '/parentForRename3' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForRename3' });
- expect(xssSpy).toHaveBeenCalled();
- expect(renameDescendantsWithStreamSpy).not.toHaveBeenCalled();
- expect(pageEventSpy).toHaveBeenCalledWith('delete', parentForRename3, testUser2, socketClientId);
- expect(pageEventSpy).toHaveBeenCalledWith('create', resultPage, testUser2, socketClientId);
- expect(resultPage.path).toBe('/renamed3');
- expect(resultPage.updatedAt).toEqual(parentForRename3.updatedAt);
- expect(resultPage.lastUpdateUser).toEqual(testUser1._id);
- expect(redirectedFromPage).not.toBeNull();
- expect(redirectedFromPage.path).toBe('/parentForRename3');
- expect(redirectedFromPage.redirectTo).toBe('/renamed3');
- expect(redirectedFromPageRevision).not.toBeNull();
- expect(redirectedFromPageRevision.path).toBe('/parentForRename3');
- expect(redirectedFromPageRevision.body).toBe('redirect /renamed3');
- });
- test('rename page with isRecursively', async() => {
- const resultPage = await crowi.pageService.renamePage(parentForRename4, '/renamed4', testUser2, { }, true);
- const redirectedFromPage = await Page.findOne({ path: '/parentForRename4' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForRename4' });
- expect(xssSpy).toHaveBeenCalled();
- expect(renameDescendantsWithStreamSpy).toHaveBeenCalled();
- expect(pageEventSpy).toHaveBeenCalledWith('delete', parentForRename4, testUser2, socketClientId);
- expect(pageEventSpy).toHaveBeenCalledWith('create', resultPage, testUser2, socketClientId);
- expect(resultPage.path).toBe('/renamed4');
- expect(resultPage.updatedAt).toEqual(parentForRename4.updatedAt);
- expect(resultPage.lastUpdateUser).toEqual(testUser1._id);
- expect(redirectedFromPage).toBeNull();
- expect(redirectedFromPageRevision).toBeNull();
- });
- });
- test('renameDescendants without options', async() => {
- const oldPagePathPrefix = new RegExp('^/parentForRename1', 'i');
- const newPagePathPrefix = '/renamed1';
- await crowi.pageService.renameDescendants([childForRename1], testUser2, {}, oldPagePathPrefix, newPagePathPrefix);
- const resultPage = await Page.findOne({ path: '/renamed1/child' });
- const redirectedFromPage = await Page.findOne({ path: '/parentForRename1/child' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForRename1/child' });
- expect(resultPage).not.toBeNull();
- expect(pageEventSpy).toHaveBeenCalledWith('updateMany', [childForRename1], testUser2);
- expect(resultPage.path).toBe('/renamed1/child');
- expect(resultPage.updatedAt).toEqual(childForRename1.updatedAt);
- expect(resultPage.lastUpdateUser).toEqual(testUser1._id);
- expect(redirectedFromPage).toBeNull();
- expect(redirectedFromPageRevision).toBeNull();
- });
- test('renameDescendants with updateMetadata option', async() => {
- const oldPagePathPrefix = new RegExp('^/parentForRename2', 'i');
- const newPagePathPrefix = '/renamed2';
- await crowi.pageService.renameDescendants([childForRename2], testUser2, { updateMetadata: true }, oldPagePathPrefix, newPagePathPrefix);
- const resultPage = await Page.findOne({ path: '/renamed2/child' });
- const redirectedFromPage = await Page.findOne({ path: '/parentForRename2/child' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForRename2/child' });
- expect(resultPage).not.toBeNull();
- expect(pageEventSpy).toHaveBeenCalledWith('updateMany', [childForRename2], testUser2);
- expect(resultPage.path).toBe('/renamed2/child');
- expect(resultPage.updatedAt).toEqual(dateToUse);
- expect(resultPage.lastUpdateUser).toEqual(testUser2._id);
- expect(redirectedFromPage).toBeNull();
- expect(redirectedFromPageRevision).toBeNull();
- });
- test('renameDescendants with createRedirectPage option', async() => {
- const oldPagePathPrefix = new RegExp('^/parentForRename3', 'i');
- const newPagePathPrefix = '/renamed3';
- await crowi.pageService.renameDescendants([childForRename3], testUser2, { createRedirectPage: true }, oldPagePathPrefix, newPagePathPrefix);
- const resultPage = await Page.findOne({ path: '/renamed3/child' });
- const redirectedFromPage = await Page.findOne({ path: '/parentForRename3/child' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForRename3/child' });
- expect(resultPage).not.toBeNull();
- expect(pageEventSpy).toHaveBeenCalledWith('updateMany', [childForRename3], testUser2);
- expect(resultPage.path).toBe('/renamed3/child');
- expect(resultPage.updatedAt).toEqual(childForRename3.updatedAt);
- expect(resultPage.lastUpdateUser).toEqual(testUser1._id);
- expect(redirectedFromPage).not.toBeNull();
- expect(redirectedFromPage.path).toBe('/parentForRename3/child');
- expect(redirectedFromPage.redirectTo).toBe('/renamed3/child');
- expect(redirectedFromPageRevision).not.toBeNull();
- expect(redirectedFromPageRevision.path).toBe('/parentForRename3/child');
- expect(redirectedFromPageRevision.body).toBe('redirect /renamed3/child');
- });
- });
- describe('duplicate page', () => {
- let duplicateDescendantsWithStreamSpy;
- jest.mock('../../server/models/serializers/page-serializer');
- const { serializePageSecurely } = require('../../server/models/serializers/page-serializer');
- serializePageSecurely.mockImplementation(page => page);
- beforeEach(async(done) => {
- duplicateDescendantsWithStreamSpy = jest.spyOn(crowi.pageService, 'duplicateDescendantsWithStream').mockImplementation();
- done();
- });
- test('duplicate page (isRecursively: false)', async() => {
- const dummyId = '600d395667536503354c9999';
- crowi.models.Page.findRelatedTagsById = jest.fn().mockImplementation(() => { return parentTag });
- const originTagsMock = jest.spyOn(Page, 'findRelatedTagsById').mockImplementation(() => { return parentTag });
- jest.spyOn(PageTagRelation, 'updatePageTags').mockImplementation(() => { return [dummyId, parentTag.name] });
- jest.spyOn(PageTagRelation, 'listTagNamesByPage').mockImplementation(() => { return [parentTag.name] });
- const resultPage = await crowi.pageService.duplicate(parentForDuplicate, '/newParentDuplicate', testUser2, false);
- const duplicatedToPageRevision = await Revision.findOne({ path: '/newParentDuplicate' });
- expect(xssSpy).toHaveBeenCalled();
- expect(duplicateDescendantsWithStreamSpy).not.toHaveBeenCalled();
- expect(serializePageSecurely).toHaveBeenCalled();
- expect(resultPage.path).toBe('/newParentDuplicate');
- expect(resultPage.lastUpdateUser._id).toEqual(testUser2._id);
- expect(duplicatedToPageRevision._id).not.toEqual(parentForDuplicate.revision._id);
- expect(resultPage.grant).toEqual(parentForDuplicate.grant);
- expect(resultPage.tags).toEqual([originTagsMock().name]);
- });
- test('duplicate page (isRecursively: true)', async() => {
- const dummyId = '600d395667536503354c9999';
- crowi.models.Page.findRelatedTagsById = jest.fn().mockImplementation(() => { return parentTag });
- const originTagsMock = jest.spyOn(Page, 'findRelatedTagsById').mockImplementation(() => { return parentTag });
- jest.spyOn(PageTagRelation, 'updatePageTags').mockImplementation(() => { return [dummyId, parentTag.name] });
- jest.spyOn(PageTagRelation, 'listTagNamesByPage').mockImplementation(() => { return [parentTag.name] });
- const resultPageRecursivly = await crowi.pageService.duplicate(parentForDuplicate, '/newParentDuplicateRecursively', testUser2, true);
- const duplicatedRecursivelyToPageRevision = await Revision.findOne({ path: '/newParentDuplicateRecursively' });
- expect(xssSpy).toHaveBeenCalled();
- expect(duplicateDescendantsWithStreamSpy).toHaveBeenCalled();
- expect(serializePageSecurely).toHaveBeenCalled();
- expect(resultPageRecursivly.path).toBe('/newParentDuplicateRecursively');
- expect(resultPageRecursivly.lastUpdateUser._id).toEqual(testUser2._id);
- expect(duplicatedRecursivelyToPageRevision._id).not.toEqual(parentForDuplicate.revision._id);
- expect(resultPageRecursivly.grant).toEqual(parentForDuplicate.grant);
- expect(resultPageRecursivly.tags).toEqual([originTagsMock().name]);
- });
- test('duplicateDescendants()', () => {
- expect(3).toBe(3);
- });
- test('duplicateTags()', () => {
- expect(3).toBe(3);
- });
- });
- describe('delete page', () => {
- let getDeletedPageNameSpy;
- let pageEventSpy;
- let deleteDescendantsWithStreamSpy;
- const dateToUse = new Date('2000-01-01');
- const socketClientId = null;
- beforeEach(async(done) => {
- jest.spyOn(global.Date, 'now').mockImplementation(() => dateToUse);
- getDeletedPageNameSpy = jest.spyOn(Page, 'getDeletedPageName');
- pageEventSpy = jest.spyOn(crowi.pageService.pageEvent, 'emit');
- deleteDescendantsWithStreamSpy = jest.spyOn(crowi.pageService, 'deleteDescendantsWithStream').mockImplementation();
- done();
- });
- test('delete page without options', async() => {
- const resultPage = await crowi.pageService.deletePage(parentForDelete1, testUser2, { });
- const redirectedFromPage = await Page.findOne({ path: '/parentForDelete1' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForDelete1' });
- expect(getDeletedPageNameSpy).toHaveBeenCalled();
- expect(deleteDescendantsWithStreamSpy).not.toHaveBeenCalled();
- expect(resultPage.status).toBe(Page.STATUS_DELETED);
- expect(resultPage.path).toBe('/trash/parentForDelete1');
- expect(resultPage.deleteUser).toEqual(testUser2._id);
- expect(resultPage.deletedAt).toEqual(dateToUse);
- expect(resultPage.updatedAt).toEqual(parentForDelete1.updatedAt);
- expect(resultPage.lastUpdateUser).toEqual(testUser1._id);
- expect(redirectedFromPage).not.toBeNull();
- expect(redirectedFromPage.path).toBe('/parentForDelete1');
- expect(redirectedFromPage.redirectTo).toBe('/trash/parentForDelete1');
- expect(redirectedFromPageRevision).not.toBeNull();
- expect(redirectedFromPageRevision.path).toBe('/parentForDelete1');
- expect(redirectedFromPageRevision.body).toBe('redirect /trash/parentForDelete1');
- expect(pageEventSpy).toHaveBeenCalledWith('delete', parentForDelete1, testUser2, socketClientId);
- expect(pageEventSpy).toHaveBeenCalledWith('create', resultPage, testUser2, socketClientId);
- });
- test('delete page with isRecursively', async() => {
- const resultPage = await crowi.pageService.deletePage(parentForDelete2, testUser2, { }, true);
- const redirectedFromPage = await Page.findOne({ path: '/parentForDelete2' });
- const redirectedFromPageRevision = await Revision.findOne({ path: '/parentForDelete2' });
- expect(getDeletedPageNameSpy).toHaveBeenCalled();
- expect(deleteDescendantsWithStreamSpy).toHaveBeenCalled();
- expect(resultPage.status).toBe(Page.STATUS_DELETED);
- expect(resultPage.path).toBe('/trash/parentForDelete2');
- expect(resultPage.deleteUser).toEqual(testUser2._id);
- expect(resultPage.deletedAt).toEqual(dateToUse);
- expect(resultPage.updatedAt).toEqual(parentForDelete2.updatedAt);
- expect(resultPage.lastUpdateUser).toEqual(testUser1._id);
- expect(redirectedFromPage).not.toBeNull();
- expect(redirectedFromPage.path).toBe('/parentForDelete2');
- expect(redirectedFromPage.redirectTo).toBe('/trash/parentForDelete2');
- expect(redirectedFromPageRevision).not.toBeNull();
- expect(redirectedFromPageRevision.path).toBe('/parentForDelete2');
- expect(redirectedFromPageRevision.body).toBe('redirect /trash/parentForDelete2');
- expect(pageEventSpy).toHaveBeenCalledWith('delete', parentForDelete2, testUser2, socketClientId);
- expect(pageEventSpy).toHaveBeenCalledWith('create', resultPage, testUser2, socketClientId);
- });
- test('deleteDescendants()', () => {
- expect(3).toBe(3);
- });
- });
- describe('delete page completely', () => {
- test('deleteCompletely()', () => {
- expect(3).toBe(3);
- });
- test('deleteMultipleCompletely()', () => {
- expect(3).toBe(3);
- });
- });
- describe('revert page', () => {
- let getRevertDeletedPageNameSpy;
- let findByPathSpy;
- let deleteCompletelySpy;
- let revertDeletedDescendantsWithStreamSpy;
- beforeEach(async(done) => {
- getRevertDeletedPageNameSpy = jest.spyOn(Page, 'getRevertDeletedPageName');
- deleteCompletelySpy = jest.spyOn(crowi.pageService, 'deleteCompletely').mockImplementation();
- revertDeletedDescendantsWithStreamSpy = jest.spyOn(crowi.pageService, 'revertDeletedDescendantsWithStream').mockImplementation();
- done();
- });
- test('revert deleted page when the redirect from page exists', async() => {
- findByPathSpy = jest.spyOn(Page, 'findByPath').mockImplementation(() => {
- return { redirectTo: '/trash/parentForRevert1' };
- });
- const resultPage = await crowi.pageService.revertDeletedPage(parentForRevert1, testUser2);
- expect(getRevertDeletedPageNameSpy).toHaveBeenCalledWith(parentForRevert1.path);
- expect(findByPathSpy).toHaveBeenCalledWith('/parentForRevert1');
- expect(deleteCompletelySpy).toHaveBeenCalled();
- expect(revertDeletedDescendantsWithStreamSpy).not.toHaveBeenCalled();
- expect(resultPage.path).toBe('/parentForRevert1');
- expect(resultPage.lastUpdateUser._id).toEqual(testUser2._id);
- expect(resultPage.status).toBe(Page.STATUS_PUBLISHED);
- expect(resultPage.deleteUser).toBeNull();
- expect(resultPage.deletedAt).toBeNull();
- });
- test('revert deleted page when the redirect from page does not exist', async() => {
- findByPathSpy = jest.spyOn(Page, 'findByPath').mockImplementation(() => {
- return null;
- });
- const resultPage = await crowi.pageService.revertDeletedPage(parentForRevert2, testUser2, {}, true);
- expect(getRevertDeletedPageNameSpy).toHaveBeenCalledWith(parentForRevert2.path);
- expect(findByPathSpy).toHaveBeenCalledWith('/parentForRevert2');
- expect(deleteCompletelySpy).not.toHaveBeenCalled();
- expect(revertDeletedDescendantsWithStreamSpy).toHaveBeenCalled();
- expect(resultPage.path).toBe('/parentForRevert2');
- expect(resultPage.lastUpdateUser._id).toEqual(testUser2._id);
- expect(resultPage.status).toBe(Page.STATUS_PUBLISHED);
- expect(resultPage.deleteUser).toBeNull();
- expect(resultPage.deletedAt).toBeNull();
- });
- test('revertDeletedPages()', () => {
- expect(3).toBe(3);
- });
- });
- });
|