mirror of
https://github.com/comfyanonymous/ComfyUI.git
synced 2025-01-11 18:35:17 +00:00
90aebb6c86
* menu * wip * wip * wip * wip * wip * workflow saving/loading * Support inserting workflows Move buttosn to top of lists * fix session storage implement renaming * temp * refactor, better workflow instance management * wip * progress on progress * added send to workflow various fixes * Support multiple image loaders * Support dynamic size breakpoints based on content * various fixes add close unsaved warning * Add filtering tree * prevent renaming unsaved * fix zindex on hover * fix top offset * use filename as workflow name * resize on setting change * hide element until it is drawn * remove glow * Fix export name * Fix test, revert accidental changes to groupNode * Fix colors on all themes * show hover items on smaller screen (mobile) * remove debugging code * dialog fix * Dont reorder open workflows Allow elements around canvas * Toggle body display on setting change * Fix menu disappearing on chrome * Increase delay when typing, remove margin on Safari, fix dialog location * Fix overflow issue on iOS * Add reset view button Prevent view changes causing history entries * Bottom menu wip * Various fixes * Fix merge * Fix breaking old menu position * Fix merge adding restore view to loadGraphData
83 lines
2.4 KiB
JavaScript
83 lines
2.4 KiB
JavaScript
require("../../web/scripts/api");
|
|
|
|
const fs = require("fs");
|
|
const path = require("path");
|
|
function* walkSync(dir) {
|
|
const files = fs.readdirSync(dir, { withFileTypes: true });
|
|
for (const file of files) {
|
|
if (file.isDirectory()) {
|
|
yield* walkSync(path.join(dir, file.name));
|
|
} else {
|
|
yield path.join(dir, file.name);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @typedef { import("../../web/types/comfy").ComfyObjectInfo } ComfyObjectInfo
|
|
*/
|
|
|
|
/**
|
|
* @param {{
|
|
* mockExtensions?: string[],
|
|
* mockNodeDefs?: Record<string, ComfyObjectInfo>,
|
|
* settings?: Record<string, string>
|
|
* userConfig?: {storage: "server" | "browser", users?: Record<string, any>, migrated?: boolean },
|
|
* userData?: Record<string, any>
|
|
* }} config
|
|
*/
|
|
export function mockApi(config = {}) {
|
|
let { mockExtensions, mockNodeDefs, userConfig, settings, userData } = {
|
|
userConfig,
|
|
settings: {},
|
|
userData: {},
|
|
...config,
|
|
};
|
|
if (!mockExtensions) {
|
|
mockExtensions = Array.from(walkSync(path.resolve("../web/extensions/core")))
|
|
.filter((x) => x.endsWith(".js"))
|
|
.map((x) => path.relative(path.resolve("../web"), x));
|
|
}
|
|
if (!mockNodeDefs) {
|
|
mockNodeDefs = JSON.parse(fs.readFileSync(path.resolve("./data/object_info.json")));
|
|
}
|
|
|
|
const events = new EventTarget();
|
|
const mockApi = {
|
|
addEventListener: events.addEventListener.bind(events),
|
|
removeEventListener: events.removeEventListener.bind(events),
|
|
dispatchEvent: events.dispatchEvent.bind(events),
|
|
getSystemStats: jest.fn(),
|
|
getExtensions: jest.fn(() => mockExtensions),
|
|
getNodeDefs: jest.fn(() => mockNodeDefs),
|
|
init: jest.fn(),
|
|
apiURL: jest.fn((x) => "../../web/" + x),
|
|
createUser: jest.fn((username) => {
|
|
if(username in userConfig.users) {
|
|
return { status: 400, json: () => "Duplicate" }
|
|
}
|
|
userConfig.users[username + "!"] = username;
|
|
return { status: 200, json: () => username + "!" }
|
|
}),
|
|
getUserConfig: jest.fn(() => userConfig ?? { storage: "browser", migrated: false }),
|
|
getSettings: jest.fn(() => settings),
|
|
storeSettings: jest.fn((v) => Object.assign(settings, v)),
|
|
getUserData: jest.fn((f) => {
|
|
if (f in userData) {
|
|
return { status: 200, json: () => userData[f] };
|
|
} else {
|
|
return { status: 404 };
|
|
}
|
|
}),
|
|
storeUserData: jest.fn((file, data) => {
|
|
userData[file] = data;
|
|
}),
|
|
listUserData: jest.fn(() => [])
|
|
};
|
|
jest.mock("../../web/scripts/api", () => ({
|
|
get api() {
|
|
return mockApi;
|
|
},
|
|
}));
|
|
}
|