|
@@ -18,7 +18,10 @@ let childForRename2;
|
|
|
let childForRename3;
|
|
let childForRename3;
|
|
|
|
|
|
|
|
let parentForDuplicate;
|
|
let parentForDuplicate;
|
|
|
-let parentForDelete;
|
|
|
|
|
|
|
+
|
|
|
|
|
+let parentForDelete1;
|
|
|
|
|
+let parentForDelete2;
|
|
|
|
|
+
|
|
|
let parentForDeleteCompletely;
|
|
let parentForDeleteCompletely;
|
|
|
|
|
|
|
|
let parentForRevert1;
|
|
let parentForRevert1;
|
|
@@ -113,7 +116,13 @@ describe('PageService', () => {
|
|
|
lastUpdateUser: testUser1,
|
|
lastUpdateUser: testUser1,
|
|
|
},
|
|
},
|
|
|
{
|
|
{
|
|
|
- path: '/parentForDelete',
|
|
|
|
|
|
|
+ path: '/parentForDelete1',
|
|
|
|
|
+ grant: Page.GRANT_PUBLIC,
|
|
|
|
|
+ creator: testUser1,
|
|
|
|
|
+ lastUpdateUser: testUser1,
|
|
|
|
|
+ },
|
|
|
|
|
+ {
|
|
|
|
|
+ path: '/parentForDelete2',
|
|
|
grant: Page.GRANT_PUBLIC,
|
|
grant: Page.GRANT_PUBLIC,
|
|
|
creator: testUser1,
|
|
creator: testUser1,
|
|
|
lastUpdateUser: testUser1,
|
|
lastUpdateUser: testUser1,
|
|
@@ -165,7 +174,10 @@ describe('PageService', () => {
|
|
|
parentForRename4 = await Page.findOne({ path: '/parentForRename4' });
|
|
parentForRename4 = await Page.findOne({ path: '/parentForRename4' });
|
|
|
|
|
|
|
|
parentForDuplicate = await Page.findOne({ path: '/parentForDuplicate' });
|
|
parentForDuplicate = await Page.findOne({ path: '/parentForDuplicate' });
|
|
|
- parentForDelete = await Page.findOne({ path: '/parentForDelete' });
|
|
|
|
|
|
|
+
|
|
|
|
|
+ parentForDelete1 = await Page.findOne({ path: '/parentForDelete1' });
|
|
|
|
|
+ parentForDelete2 = await Page.findOne({ path: '/parentForDelete2' });
|
|
|
|
|
+
|
|
|
parentForDeleteCompletely = await Page.findOne({ path: '/parentForDeleteCompletely' });
|
|
parentForDeleteCompletely = await Page.findOne({ path: '/parentForDeleteCompletely' });
|
|
|
parentForRevert1 = await Page.findOne({ path: '/trash/parentForRevert1' });
|
|
parentForRevert1 = await Page.findOne({ path: '/trash/parentForRevert1' });
|
|
|
parentForRevert2 = await Page.findOne({ path: '/trash/parentForRevert2' });
|
|
parentForRevert2 = await Page.findOne({ path: '/trash/parentForRevert2' });
|
|
@@ -434,10 +446,77 @@ describe('PageService', () => {
|
|
|
});
|
|
});
|
|
|
|
|
|
|
|
describe('delete page', () => {
|
|
describe('delete page', () => {
|
|
|
- test('deletePage()', () => {
|
|
|
|
|
- expect(3).toBe(3);
|
|
|
|
|
|
|
+ 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()', () => {
|
|
test('deleteDescendants()', () => {
|
|
|
expect(3).toBe(3);
|
|
expect(3).toBe(3);
|
|
|
});
|
|
});
|