@graphql-inspector/core
Version:
Tooling for GraphQL. Compare GraphQL Schemas, check documents, find breaking changes, find similar types.
50 lines (49 loc) • 2.02 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.considerUsage = void 0;
const path_js_1 = require("../../utils/path.js");
const change_js_1 = require("../changes/change.js");
const considerUsage = async ({ changes, config }) => {
if (!config) {
throw new Error(`considerUsage rule is missing config`);
}
const collectedBreakingField = [];
for (const change of changes) {
if (change.criticality.level === change_js_1.CriticalityLevel.Breaking && change.path) {
const [typeName, fieldName, argumentName] = (0, path_js_1.parsePath)(change.path);
collectedBreakingField.push({
type: typeName,
field: fieldName,
argument: argumentName,
meta: {
change,
},
});
}
}
// True if safe to break, false otherwise
const usageList = await config.checkUsage(collectedBreakingField);
// turns an array of booleans into an array of `Type.Field` strings
// includes only those that are safe to break the api
const suppressedPaths = collectedBreakingField
.filter((_, i) => usageList[i] === true)
.map(({ type, field, argument }) => [type, field, argument].filter(Boolean).join('.'));
return changes.map(change => {
// Turns those "safe to break" changes into "dangerous"
if (change.criticality.level === change_js_1.CriticalityLevel.Breaking &&
change.path &&
suppressedPaths.some(p => change.path.startsWith(p))) {
return {
...change,
criticality: {
...change.criticality,
level: change_js_1.CriticalityLevel.Dangerous,
isSafeBasedOnUsage: true,
},
message: `${change.message} (non-breaking based on usage)`,
};
}
return change;
});
};
exports.considerUsage = considerUsage;
;