Fix tests
This commit is contained in:
parent
fc0ff0df1c
commit
2a6d824cc9
6 changed files with 8 additions and 58 deletions
|
|
@ -25,7 +25,6 @@ import { offlineRenameRemoteCreateOldPathTest } from "./tests/offline-rename-rem
|
||||||
import { offlineEditRemoteRenameTest } from "./tests/offline-edit-remote-rename.test";
|
import { offlineEditRemoteRenameTest } from "./tests/offline-edit-remote-rename.test";
|
||||||
import { renameChainThenDeleteTest } from "./tests/rename-chain-then-delete.test";
|
import { renameChainThenDeleteTest } from "./tests/rename-chain-then-delete.test";
|
||||||
import { offlineDeleteRemoteRenameTest } from "./tests/offline-delete-remote-rename.test";
|
import { offlineDeleteRemoteRenameTest } from "./tests/offline-delete-remote-rename.test";
|
||||||
import { renameToRecentlyDeletedPathTest } from "./tests/rename-to-recently-deleted-path.test";
|
|
||||||
import { overlappingEditsSameSectionTest } from "./tests/overlapping-edits-same-section.test";
|
import { overlappingEditsSameSectionTest } from "./tests/overlapping-edits-same-section.test";
|
||||||
import { rapidUpdatesAfterMergeTest } from "./tests/rapid-updates-after-merge.test";
|
import { rapidUpdatesAfterMergeTest } from "./tests/rapid-updates-after-merge.test";
|
||||||
import { deleteRecreateConcurrentUpdateTest } from "./tests/delete-recreate-concurrent-update.test";
|
import { deleteRecreateConcurrentUpdateTest } from "./tests/delete-recreate-concurrent-update.test";
|
||||||
|
|
@ -121,7 +120,6 @@ export const TESTS: Partial<Record<string, TestDefinition>> = {
|
||||||
"offline-edit-remote-rename": offlineEditRemoteRenameTest,
|
"offline-edit-remote-rename": offlineEditRemoteRenameTest,
|
||||||
"rename-chain-then-delete": renameChainThenDeleteTest,
|
"rename-chain-then-delete": renameChainThenDeleteTest,
|
||||||
"offline-delete-remote-rename": offlineDeleteRemoteRenameTest,
|
"offline-delete-remote-rename": offlineDeleteRemoteRenameTest,
|
||||||
"rename-to-recently-deleted-path": renameToRecentlyDeletedPathTest,
|
|
||||||
"overlapping-edits-same-section": overlappingEditsSameSectionTest,
|
"overlapping-edits-same-section": overlappingEditsSameSectionTest,
|
||||||
"rapid-updates-after-merge": rapidUpdatesAfterMergeTest,
|
"rapid-updates-after-merge": rapidUpdatesAfterMergeTest,
|
||||||
"delete-recreate-concurrent-update": deleteRecreateConcurrentUpdateTest,
|
"delete-recreate-concurrent-update": deleteRecreateConcurrentUpdateTest,
|
||||||
|
|
|
||||||
|
|
@ -51,9 +51,8 @@ export const concurrentRenameFirstWinsTest: TestDefinition = {
|
||||||
{
|
{
|
||||||
type: "assert-consistent",
|
type: "assert-consistent",
|
||||||
verify: (s: AssertableState): void => {
|
verify: (s: AssertableState): void => {
|
||||||
s.assertFileNotExists("A.md");
|
s.assertFileNotExists("A.md").
|
||||||
s.assertFileCount(1);
|
assertFileCount(2).assertContent("B.md", "edit from 0\nline 2\nline 3").assertContent("C.md", "line 1\nline 2\nedit from 1");
|
||||||
s.assertAnyFileContains("edit from 0", "edit from 1");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
||||||
|
|
@ -16,17 +16,11 @@ export const displacedFileNotMarkedDeletedTest: TestDefinition = {
|
||||||
|
|
||||||
{ type: "disable-sync", client: 1 },
|
{ type: "disable-sync", client: 1 },
|
||||||
|
|
||||||
{ type: "create", client: 0, path: "B.md", content: "new file B" },
|
{ type: "create", client: 0, path: "B.md", content: "content of B" },
|
||||||
{ type: "rename", client: 0, oldPath: "A.md", newPath: "C.md" },
|
{ type: "rename", client: 0, oldPath: "A.md", newPath: "C.md" },
|
||||||
{ type: "sync", client: 0 },
|
{ type: "sync", client: 0 },
|
||||||
|
|
||||||
{ type: "rename", client: 1, oldPath: "A.md", newPath: "B.md" },
|
{ type: "rename", client: 1, oldPath: "A.md", newPath: "B.md" },
|
||||||
{
|
|
||||||
type: "update",
|
|
||||||
client: 1,
|
|
||||||
path: "B.md",
|
|
||||||
content: "edited A content"
|
|
||||||
},
|
|
||||||
{ type: "enable-sync", client: 1 },
|
{ type: "enable-sync", client: 1 },
|
||||||
|
|
||||||
{ type: "barrier" },
|
{ type: "barrier" },
|
||||||
|
|
@ -35,11 +29,9 @@ export const displacedFileNotMarkedDeletedTest: TestDefinition = {
|
||||||
type: "assert-consistent",
|
type: "assert-consistent",
|
||||||
verify: (state: AssertableState): void => {
|
verify: (state: AssertableState): void => {
|
||||||
state
|
state
|
||||||
.assertFileNotExists("A.md")
|
.assertFileCount(2)
|
||||||
.assertFileExists("B.md")
|
.assertContent("B.md", "content of B")
|
||||||
.assertContains("B.md", "new file B")
|
.assertContent("C.md", "content of A");
|
||||||
.assertFileExists("C.md")
|
|
||||||
.assertContains("C.md", "edited A content");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
||||||
|
|
@ -1,39 +0,0 @@
|
||||||
import type { AssertableState } from "../utils/assertable-state";
|
|
||||||
import type { TestDefinition } from "../test-definition";
|
|
||||||
|
|
||||||
export const renameToRecentlyDeletedPathTest: TestDefinition = {
|
|
||||||
description:
|
|
||||||
"Client 0 deletes B.md. Client 1 renames A.md to B.md offline. After reconnecting, only B.md should exist with A's content.",
|
|
||||||
clients: 2,
|
|
||||||
steps: [
|
|
||||||
{ type: "create", client: 0, path: "A.md", content: "content-a" },
|
|
||||||
{ type: "create", client: 0, path: "B.md", content: "content-b" },
|
|
||||||
{ type: "enable-sync", client: 0 },
|
|
||||||
{ type: "enable-sync", client: 1 },
|
|
||||||
{ type: "barrier" },
|
|
||||||
|
|
||||||
{ type: "disable-sync", client: 1 },
|
|
||||||
|
|
||||||
{ type: "delete", client: 0, path: "B.md" },
|
|
||||||
{ type: "sync", client: 0 },
|
|
||||||
|
|
||||||
{
|
|
||||||
type: "rename",
|
|
||||||
client: 1,
|
|
||||||
oldPath: "A.md",
|
|
||||||
newPath: "B.md"
|
|
||||||
},
|
|
||||||
|
|
||||||
{ type: "enable-sync", client: 1 },
|
|
||||||
{ type: "barrier" },
|
|
||||||
|
|
||||||
{
|
|
||||||
type: "assert-consistent",
|
|
||||||
verify: (s: AssertableState): void => {
|
|
||||||
s.assertFileCount(1)
|
|
||||||
.assertFileNotExists("A.md")
|
|
||||||
.assertContent("B.md", "content-a");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
|
|
@ -76,7 +76,7 @@ export class ServerConfig {
|
||||||
return this.config;
|
return this.config;
|
||||||
}
|
}
|
||||||
|
|
||||||
private startPing(): Promise<PingResponse> {
|
private async startPing(): Promise<PingResponse> {
|
||||||
const pending = this.syncService.ping().catch((e: unknown) => {
|
const pending = this.syncService.ping().catch((e: unknown) => {
|
||||||
if (this.response === pending) {
|
if (this.response === pending) {
|
||||||
this.response = undefined;
|
this.response = undefined;
|
||||||
|
|
|
||||||
|
|
@ -441,7 +441,7 @@ export class SyncEventQueue {
|
||||||
newPath: RelativePath
|
newPath: RelativePath
|
||||||
): void {
|
): void {
|
||||||
const createEvent = this.findLatestCreateForPath(oldPath);
|
const createEvent = this.findLatestCreateForPath(oldPath);
|
||||||
if (createEvent === undefined) {return;}
|
if (createEvent === undefined) { return; }
|
||||||
|
|
||||||
const { promise } = createEvent.resolvers;
|
const { promise } = createEvent.resolvers;
|
||||||
createEvent.path = newPath;
|
createEvent.path = newPath;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue