Skip to content

Commit

Permalink
fix: Broken error handling (#302)
Browse files Browse the repository at this point in the history
* fix: Broken error handling

* fix: Ensure expectations are checked regardless of throw
  • Loading branch information
Tom Moor committed Jul 31, 2020
1 parent 5860f5f commit c48321c
Show file tree
Hide file tree
Showing 7 changed files with 64 additions and 26 deletions.
9 changes: 5 additions & 4 deletions src/endpoints/Endpoint.js
Original file line number Diff line number Diff line change
Expand Up @@ -90,10 +90,11 @@ export default class Endpoint {
}
}

if (
transportMode.length > 1 &&
Object.keys(errors).length === transportMode.length
) {
const totalErrors = Object.keys(errors).length;
if (transportMode.length === totalErrors) {
if (totalErrors === 1) {
throw Object.values(errors)[0];
}
throw new MultiError(errors);
}

Expand Down
45 changes: 36 additions & 9 deletions tests/Client.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,26 +19,50 @@ describe("Client", () => {
test("no transports specified", async () => {
expect.assertions(1);

let error;
try {
await API_CLIENT.organizations.list({
transportMode: []
});
} catch (error) {
expect(error).toBeInstanceOf(EndpointUndefinedError);
} catch (e) {
error = e;
}
expect(error).toBeInstanceOf(EndpointUndefinedError);
});

test("endpoint undefined in all transports", async () => {
expect.assertions(2);

let error;
try {
await API_CLIENT.organizations.list({
transportMode: ["api", "cli"]
});
} catch (error) {
expect(error).toBeInstanceOf(MultiError);
expect(error.errors.cli).toBeInstanceOf(EndpointUndefinedError);
} catch (e) {
error = e;
}
expect(error).toBeInstanceOf(MultiError);
expect(error && error.errors.cli).toBeInstanceOf(EndpointUndefinedError);
});

test("individual transport throws", async () => {
mockAPI("/projects/project-id/branches/?", { ok: false }, 404);

let error;
try {
await API_CLIENT.branches.list(
{
projectId: "project-id"
},
{
transportMode: ["api"]
}
);
} catch (e) {
error = e;
}

expect(error).toBeInstanceOf(NotFoundError);
});

test("all transports throw", async () => {
Expand All @@ -48,6 +72,7 @@ describe("Client", () => {
code: "not_found"
});

let error;
try {
await API_CLIENT.branches.list(
{
Expand All @@ -57,11 +82,13 @@ describe("Client", () => {
transportMode: ["api", "cli"]
}
);
} catch (error) {
expect(error).toBeInstanceOf(MultiError);
expect(error.errors.api).toBeInstanceOf(NotFoundError);
expect(error.errors.cli).toBeInstanceOf(NotFoundError);
} catch (e) {
error = e;
}

expect(error).toBeInstanceOf(MultiError);
expect(error && error.errors.api).toBeInstanceOf(NotFoundError);
expect(error && error.errors.cli).toBeInstanceOf(NotFoundError);
});

test("attempts all transports in order", async () => {
Expand Down
6 changes: 4 additions & 2 deletions tests/endpoints/Branches.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -206,11 +206,13 @@ describe("branches", () => {
});

test("cli - no descriptor", async () => {
let error;
try {
await CLI_CLIENT.branches.list(undefined);
} catch (error) {
expect(error.errors.cli).toBeInstanceOf(BranchSearchCLIError);
} catch (e) {
error = e;
}
expect(error).toBeInstanceOf(BranchSearchCLIError);
});
});

Expand Down
12 changes: 8 additions & 4 deletions tests/endpoints/Files.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,16 +40,18 @@ describe("files", () => {
]
});

let error;
try {
await API_CLIENT.files.info({
branchId: "branch-id",
fileId: "file-id",
projectId: "project-id",
sha: "sha"
});
} catch (error) {
expect(error.errors.api).toBeInstanceOf(NotFoundError);
} catch (e) {
error = e;
}
expect(error).toBeInstanceOf(NotFoundError);
});

test("cli", async () => {
Expand Down Expand Up @@ -213,16 +215,18 @@ describe("files", () => {
);
});

let error;
try {
await API_CLIENT.files.raw({
branchId: "branch-id",
fileId: "file-id",
projectId: "project-id",
sha: "sha"
});
} catch (error) {
expect(error.errors.api).toBeInstanceOf(FileExportError);
} catch (e) {
error = e;
}
expect(error).toBeInstanceOf(FileExportError);
});

test("cli - exports file", async () => {
Expand Down
8 changes: 5 additions & 3 deletions tests/endpoints/Pages.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ describe("pages", () => {
sha: "sha"
});
} catch (error) {
expect(error.errors.api).toBeInstanceOf(NotFoundError);
expect(error).toBeInstanceOf(NotFoundError);
}
});

Expand Down Expand Up @@ -84,6 +84,7 @@ describe("pages", () => {
]
});

let error;
try {
await CLI_CLIENT.pages.info({
branchId: "branch-id",
Expand All @@ -92,9 +93,10 @@ describe("pages", () => {
projectId: "project-id",
sha: "sha"
});
} catch (error) {
expect(error.errors.cli).toBeInstanceOf(NotFoundError);
} catch (e) {
error = e;
}
expect(error).toBeInstanceOf(NotFoundError);
});
});

Expand Down
2 changes: 1 addition & 1 deletion tests/errors.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ describe("errors", () => {
try {
await CLI_CLIENT.projects.list({ organizationId: "org-id" });
} catch (error) {
expect(error.errors.cli).toBeInstanceOf(EndpointUndefinedError);
expect(error).toBeInstanceOf(EndpointUndefinedError);
}
});

Expand Down
8 changes: 5 additions & 3 deletions tests/util/helpers.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,14 @@ describe("helpers", () => {
});

test("inferShareId throws", () => {
let error;
try {
utils.inferShareId(({}: any));
} catch (error) {
expect(error).toBeInstanceOf(Error);
expect(error.message).toContain("Could not infer share id");
} catch (e) {
error = e;
}
expect(error).toBeInstanceOf(Error);
expect(error && error.message).toContain("Could not infer share id");
});

test("isNodeEnvironment", () => {
Expand Down

0 comments on commit c48321c

Please sign in to comment.