Skip to content

Commit

Permalink
All: Ensure that timestamps are not changed when sharing or unsharing…
Browse files Browse the repository at this point in the history
… a note
  • Loading branch information
laurent22 committed Jul 19, 2021
1 parent b2de27b commit cafaa9c
Show file tree
Hide file tree
Showing 4 changed files with 90 additions and 3 deletions.
3 changes: 3 additions & 0 deletions .eslintignore
Expand Up @@ -1403,6 +1403,9 @@ packages/lib/services/searchengine/queryBuilder.js.map
packages/lib/services/share/ShareService.d.ts
packages/lib/services/share/ShareService.js
packages/lib/services/share/ShareService.js.map
packages/lib/services/share/ShareService.test.d.ts
packages/lib/services/share/ShareService.test.js
packages/lib/services/share/ShareService.test.js.map
packages/lib/services/share/reducer.d.ts
packages/lib/services/share/reducer.js
packages/lib/services/share/reducer.js.map
Expand Down
3 changes: 3 additions & 0 deletions .gitignore
Expand Up @@ -1389,6 +1389,9 @@ packages/lib/services/searchengine/queryBuilder.js.map
packages/lib/services/share/ShareService.d.ts
packages/lib/services/share/ShareService.js
packages/lib/services/share/ShareService.js.map
packages/lib/services/share/ShareService.test.d.ts
packages/lib/services/share/ShareService.test.js
packages/lib/services/share/ShareService.test.js.map
packages/lib/services/share/reducer.d.ts
packages/lib/services/share/reducer.js
packages/lib/services/share/reducer.js.map
Expand Down
66 changes: 66 additions & 0 deletions packages/lib/services/share/ShareService.test.ts
@@ -0,0 +1,66 @@
import Note from '../../models/Note';
import { msleep, setupDatabaseAndSynchronizer, switchClient } from '../../testing/test-utils';
import ShareService from './ShareService';
import reducer from '../../reducer';
import { createStore } from 'redux';
import { NoteEntity } from '../database/types';

function mockApi() {
return {
exec: (method: string, path: string = '', _query: Record<string, any> = null, _body: any = null, _headers: any = null, _options: any = null): Promise<any> => {
if (method === 'GET' && path === 'api/shares') return { items: [] } as any;
return null;
},
personalizedUserContentBaseUrl(_userId: string) {

},
};
}

function mockService() {
const service = new ShareService();
const store = createStore(reducer as any);
service.initialize(store, mockApi() as any);
return service;
}

describe('ShareService', function() {

beforeEach(async (done) => {
await setupDatabaseAndSynchronizer(1);
await switchClient(1);
done();
});

it('should not change the note user timestamps when sharing or unsharing', (async () => {
let note = await Note.save({});
const service = mockService();
await msleep(1);
await service.shareNote(note.id);

function checkTimestamps(previousNote: NoteEntity, newNote: NoteEntity) {
// After sharing or unsharing, only the updated_time property should
// be updated, for sync purposes. All other timestamps shouldn't
// change.
expect(previousNote.user_created_time).toBe(newNote.user_created_time);
expect(previousNote.user_updated_time).toBe(newNote.user_updated_time);
expect(previousNote.updated_time < newNote.updated_time).toBe(true);
expect(previousNote.created_time).toBe(newNote.created_time);
}

{
const noteReloaded = await Note.load(note.id);
checkTimestamps(note, noteReloaded);
note = noteReloaded;
}

await msleep(1);
await service.unshareNote(note.id);

{
const noteReloaded = await Note.load(note.id);
checkTimestamps(note, noteReloaded);
}
}));

});
21 changes: 18 additions & 3 deletions packages/lib/services/share/ShareService.ts
Expand Up @@ -20,8 +20,9 @@ export default class ShareService {
return this.instance_;
}

public initialize(store: Store<any>) {
public initialize(store: Store<any>, api: JoplinServerApi = null) {
this.store_ = store;
this.api_ = api;
}

public get enabled(): boolean {
Expand Down Expand Up @@ -120,7 +121,14 @@ export default class ShareService {

const share = await this.api().exec('POST', 'api/shares', {}, { note_id: noteId });

await Note.save({ id: note.id, is_shared: 1 });
await Note.save({
id: note.id,
parent_id: note.parent_id,
is_shared: 1,
updated_time: Date.now(),
}, {
autoTimestamp: false,
});

return share;
}
Expand All @@ -140,7 +148,14 @@ export default class ShareService {

await Promise.all(promises);

await Note.save({ id: note.id, is_shared: 0 });
await Note.save({
id: note.id,
parent_id: note.parent_id,
is_shared: 0,
updated_time: Date.now(),
}, {
autoTimestamp: false,
});
}

public shareUrl(userId: string, share: StateShare): string {
Expand Down

0 comments on commit cafaa9c

Please sign in to comment.