Testing Error Handling Implementation in Apache Airflow
This test suite validates the error handling functionality in Apache Airflow’s web interface. It thoroughly tests the handleError utility function which processes various types of errors including Axios errors, standard Error objects, and string messages.
Test Coverage Overview
Implementation Analysis
Technical Details
Best Practices Demonstrated
apache/airflow
airflow/www/static/js/utils/handleError.test.ts
/*!
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
/* global describe, test, expect */
import type { AxiosError, AxiosResponse } from "axios";
import handleError from "./handleError";
describe("Test handleError()", () => {
test("Returns expected results", () => {
let description;
// @ts-ignore
const axiosError: AxiosError = new Error("Error message");
axiosError.toJSON = () => ({});
axiosError.response = {
data: "Not available for this Executor",
status: 400,
statusText: "BadRequest",
headers: {},
config: {},
} as AxiosResponse;
axiosError.isAxiosError = true;
// if response.data is defined
description = handleError(axiosError);
expect(description).toBe("Not available for this Executor");
axiosError.response.data = "";
// if it is not, use the error message
description = handleError(axiosError);
expect(description).toBe("Error message");
// if error object, return the message
description = handleError(new Error("no no"));
expect(description).toBe("no no");
// if string, return the string
description = handleError("error!");
expect(description).toBe("error!");
// if it's undefined, use a fallback
description = handleError(null, "fallback");
expect(description).toBe("fallback");
// use default if nothing is defined
description = handleError();
expect(description).toBe("Something went wrong.");
});
});