* Add vue-rx, rxjs and lodash as dependencies * Added vue-rx plugin integration to nuxt config * Initial settings store implementation * Add babel plugin for private class properties to for Jest * Add DispatchingStore test spec * Initial settings code * Reactive Streams for fb current user and id token * Fix typo * Migrate index and graphql pages to the new store * Migrate network strategy to the new store * Fixed Section.vue errors * Fix getSettingSubject issue * Migrate fb settings reference in components to the new state system * Add typings for lodash as dev dependency * Load setting * Load initial sync setting values * Update proxy url * Add typescript support * Rewrite Settings store to TypeScript * Port Settings page to TypeScript as reference * Move all store migrations to a separate file * Delete test file for fb.js * Add ts-jest as dev dependency * Remove firebase-mock as dependency * Remove FRAME_COLORS_ENABLED settings value
61 lines
1.4 KiB
JavaScript
61 lines
1.4 KiB
JavaScript
import axios from "axios"
|
|
import axiosStrategy from "../AxiosStrategy"
|
|
|
|
jest.mock("axios")
|
|
jest.mock("~/newstore/settings", () => {
|
|
return {
|
|
__esModule: true,
|
|
settingsStore: {
|
|
value: {
|
|
PROXY_ENABLED: false
|
|
}
|
|
}
|
|
}
|
|
})
|
|
|
|
axios.CancelToken.source.mockReturnValue({ token: "test" })
|
|
axios.mockResolvedValue({})
|
|
|
|
describe("axiosStrategy", () => {
|
|
describe("No-Proxy Requests", () => {
|
|
|
|
test("sends request to the actual sender if proxy disabled", async () => {
|
|
await axiosStrategy({ url: "test" })
|
|
|
|
expect(axios).toBeCalledWith(
|
|
expect.objectContaining({
|
|
url: "test",
|
|
})
|
|
)
|
|
})
|
|
|
|
test("asks axios to return data as arraybuffer", async () => {
|
|
await axiosStrategy({ url: "test" })
|
|
|
|
expect(axios).toBeCalledWith(
|
|
expect.objectContaining({
|
|
responseType: "arraybuffer",
|
|
})
|
|
)
|
|
})
|
|
|
|
test("resolves successful requests", async () => {
|
|
await expect(axiosStrategy({})).resolves.toBeDefined()
|
|
})
|
|
|
|
test("rejects cancel errors with text 'cancellation'", async () => {
|
|
axios.isCancel.mockReturnValueOnce(true)
|
|
axios.mockRejectedValue("err")
|
|
|
|
expect(axiosStrategy({})).rejects.toBe("cancellation")
|
|
})
|
|
|
|
test("rejects non-cancellation errors as-is", async () => {
|
|
axios.isCancel.mockReturnValueOnce(false)
|
|
axios.mockRejectedValue("err")
|
|
|
|
expect(axiosStrategy({})).rejects.toBe("err")
|
|
})
|
|
})
|
|
})
|