@sudobility/testomniac_lib 0.0.22 → 0.0.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/business/hooks/index.d.ts +3 -1
- package/dist/business/hooks/index.d.ts.map +1 -1
- package/dist/business/hooks/index.js +3 -1
- package/dist/business/hooks/index.js.map +1 -1
- package/dist/business/hooks/useDashboardManager.d.ts +18 -0
- package/dist/business/hooks/useDashboardManager.d.ts.map +1 -0
- package/dist/business/hooks/useDashboardManager.js +37 -0
- package/dist/business/hooks/useDashboardManager.js.map +1 -0
- package/dist/business/hooks/useRunManager.d.ts +31 -0
- package/dist/business/hooks/useRunManager.d.ts.map +1 -0
- package/dist/business/hooks/useRunManager.js +75 -0
- package/dist/business/hooks/useRunManager.js.map +1 -0
- package/dist/business/hooks/useScanManager.d.ts +27 -0
- package/dist/business/hooks/useScanManager.d.ts.map +1 -0
- package/dist/business/hooks/useScanManager.js +50 -0
- package/dist/business/hooks/useScanManager.js.map +1 -0
- package/dist/business/stores/index.d.ts +1 -1
- package/dist/business/stores/index.d.ts.map +1 -1
- package/dist/business/stores/index.js +1 -1
- package/dist/business/stores/index.js.map +1 -1
- package/dist/business/stores/scanProgressStore.d.ts +22 -0
- package/dist/business/stores/scanProgressStore.d.ts.map +1 -0
- package/dist/business/stores/scanProgressStore.js +75 -0
- package/dist/business/stores/scanProgressStore.js.map +1 -0
- package/package.json +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { NetworkClient } from '@sudobility/types';
|
|
2
|
+
import type { ProjectSummaryResponse } from '@sudobility/testomniac_types';
|
|
3
|
+
import type { FirebaseIdToken } from '@sudobility/testomniac_client';
|
|
4
|
+
interface UseDashboardManagerConfig {
|
|
5
|
+
networkClient: NetworkClient;
|
|
6
|
+
baseUrl: string;
|
|
7
|
+
entitySlug: string;
|
|
8
|
+
token: FirebaseIdToken;
|
|
9
|
+
enabled?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare function useDashboardManager(config: UseDashboardManagerConfig): {
|
|
12
|
+
projects: ProjectSummaryResponse[];
|
|
13
|
+
isLoading: boolean;
|
|
14
|
+
error: Error | null;
|
|
15
|
+
refetchProjects: () => Promise<void>;
|
|
16
|
+
};
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=useDashboardManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDashboardManager.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/useDashboardManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AAC3E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAGrE,UAAU,yBAAyB;IACjC,aAAa,EAAE,aAAa,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,eAAe,CAAC;IACvB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,yBAAyB;;;;;EAyCpE"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
2
|
+
import { TestomniacClient } from '@sudobility/testomniac_client';
|
|
3
|
+
export function useDashboardManager(config) {
|
|
4
|
+
const { networkClient, baseUrl, entitySlug, token, enabled = true } = config;
|
|
5
|
+
const [projects, setProjects] = useState([]);
|
|
6
|
+
const [isLoading, setIsLoading] = useState(false);
|
|
7
|
+
const [error, setError] = useState(null);
|
|
8
|
+
const client = useMemo(() => new TestomniacClient({ networkClient, baseUrl }), [networkClient, baseUrl]);
|
|
9
|
+
const fetchProjects = useCallback(async () => {
|
|
10
|
+
setIsLoading(true);
|
|
11
|
+
setError(null);
|
|
12
|
+
try {
|
|
13
|
+
const response = await client.getEntityProjects(entitySlug, token);
|
|
14
|
+
if (response.success && response.data) {
|
|
15
|
+
setProjects(response.data);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
catch (err) {
|
|
19
|
+
setError(err instanceof Error ? err : new Error('Failed to fetch projects'));
|
|
20
|
+
}
|
|
21
|
+
finally {
|
|
22
|
+
setIsLoading(false);
|
|
23
|
+
}
|
|
24
|
+
}, [client, entitySlug, token]);
|
|
25
|
+
useEffect(() => {
|
|
26
|
+
if (enabled) {
|
|
27
|
+
void fetchProjects();
|
|
28
|
+
}
|
|
29
|
+
}, [enabled, fetchProjects]);
|
|
30
|
+
return {
|
|
31
|
+
projects,
|
|
32
|
+
isLoading,
|
|
33
|
+
error,
|
|
34
|
+
refetchProjects: fetchProjects,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=useDashboardManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDashboardManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useDashboardManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAIlE,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAUjE,MAAM,UAAU,mBAAmB,CAAC,MAAiC;IACnE,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;IAE7E,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAA2B,EAAE,CAAC,CAAC;IACvE,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IAEvD,MAAM,MAAM,GAAG,OAAO,CACpB,GAAG,EAAE,CAAC,IAAI,gBAAgB,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EACtD,CAAC,aAAa,EAAE,OAAO,CAAC,CACzB,CAAC;IAEF,MAAM,aAAa,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAC3C,YAAY,CAAC,IAAI,CAAC,CAAC;QACnB,QAAQ,CAAC,IAAI,CAAC,CAAC;QACf,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;YACnE,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,QAAQ,CACN,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,0BAA0B,CAAC,CACnE,CAAC;QACJ,CAAC;gBAAS,CAAC;YACT,YAAY,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC;IAEhC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE,CAAC;YACZ,KAAK,aAAa,EAAE,CAAC;QACvB,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IAE7B,OAAO;QACL,QAAQ;QACR,SAAS;QACT,KAAK;QACL,eAAe,EAAE,aAAa;KAC/B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { NetworkClient } from '@sudobility/types';
|
|
2
|
+
import type { IssueResponse, PageResponse, PersonaResponse, RunDetailResponse, TestCaseResponse, TestRunResponse } from '@sudobility/testomniac_types';
|
|
3
|
+
import type { FirebaseIdToken } from '@sudobility/testomniac_client';
|
|
4
|
+
interface UseRunManagerConfig {
|
|
5
|
+
networkClient: NetworkClient;
|
|
6
|
+
baseUrl: string;
|
|
7
|
+
runId: number;
|
|
8
|
+
token: FirebaseIdToken;
|
|
9
|
+
enabled?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare function useRunManager(config: UseRunManagerConfig): {
|
|
12
|
+
run: RunDetailResponse | null;
|
|
13
|
+
pages: PageResponse[];
|
|
14
|
+
testCases: TestCaseResponse[];
|
|
15
|
+
testRuns: TestRunResponse[];
|
|
16
|
+
issues: IssueResponse[];
|
|
17
|
+
personas: PersonaResponse[];
|
|
18
|
+
components: unknown[];
|
|
19
|
+
isLoading: boolean;
|
|
20
|
+
error: Error | null;
|
|
21
|
+
counts: {
|
|
22
|
+
pages: number;
|
|
23
|
+
testCases: number;
|
|
24
|
+
testRuns: number;
|
|
25
|
+
issues: number;
|
|
26
|
+
personas: number;
|
|
27
|
+
components: number;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
export {};
|
|
31
|
+
//# sourceMappingURL=useRunManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRunManager.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/useRunManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EACV,aAAa,EACb,YAAY,EACZ,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EAChB,eAAe,EAChB,MAAM,8BAA8B,CAAC;AACtC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAGrE,UAAU,mBAAmB;IAC3B,aAAa,EAAE,aAAa,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,eAAe,CAAC;IACvB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,aAAa,CAAC,MAAM,EAAE,mBAAmB;;;;;;;;;;;;;;;;;;EAqFxD"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
2
|
+
import { TestomniacClient } from '@sudobility/testomniac_client';
|
|
3
|
+
export function useRunManager(config) {
|
|
4
|
+
const { networkClient, baseUrl, runId, token, enabled = true } = config;
|
|
5
|
+
const [run, setRun] = useState(null);
|
|
6
|
+
const [pages, setPages] = useState([]);
|
|
7
|
+
const [testCases, setTestCases] = useState([]);
|
|
8
|
+
const [testRuns, setTestRuns] = useState([]);
|
|
9
|
+
const [issues, setIssues] = useState([]);
|
|
10
|
+
const [personas, setPersonas] = useState([]);
|
|
11
|
+
const [components, setComponents] = useState([]);
|
|
12
|
+
const [isLoading, setIsLoading] = useState(false);
|
|
13
|
+
const [error, setError] = useState(null);
|
|
14
|
+
const client = useMemo(() => new TestomniacClient({ networkClient, baseUrl }), [networkClient, baseUrl]);
|
|
15
|
+
const fetchAll = useCallback(async () => {
|
|
16
|
+
setIsLoading(true);
|
|
17
|
+
setError(null);
|
|
18
|
+
try {
|
|
19
|
+
const [runRes, pagesRes, testCasesRes, testRunsRes, issuesRes, personasRes, componentsRes,] = await Promise.all([
|
|
20
|
+
client.getRun(runId, token),
|
|
21
|
+
client.getRunPages(runId, token),
|
|
22
|
+
client.getRunTestCases(runId, token),
|
|
23
|
+
client.getRunTestRuns(runId, token),
|
|
24
|
+
client.getRunIssues(runId, token),
|
|
25
|
+
client.getRunPersonas(runId, token),
|
|
26
|
+
client.getRunComponents(runId, token),
|
|
27
|
+
]);
|
|
28
|
+
if (runRes.success && runRes.data)
|
|
29
|
+
setRun(runRes.data);
|
|
30
|
+
if (pagesRes.success && pagesRes.data)
|
|
31
|
+
setPages(pagesRes.data);
|
|
32
|
+
if (testCasesRes.success && testCasesRes.data)
|
|
33
|
+
setTestCases(testCasesRes.data);
|
|
34
|
+
if (testRunsRes.success && testRunsRes.data)
|
|
35
|
+
setTestRuns(testRunsRes.data);
|
|
36
|
+
if (issuesRes.success && issuesRes.data)
|
|
37
|
+
setIssues(issuesRes.data);
|
|
38
|
+
if (personasRes.success && personasRes.data)
|
|
39
|
+
setPersonas(personasRes.data);
|
|
40
|
+
if (componentsRes.success && componentsRes.data)
|
|
41
|
+
setComponents(componentsRes.data);
|
|
42
|
+
}
|
|
43
|
+
catch (err) {
|
|
44
|
+
setError(err instanceof Error ? err : new Error('Failed to fetch run data'));
|
|
45
|
+
}
|
|
46
|
+
finally {
|
|
47
|
+
setIsLoading(false);
|
|
48
|
+
}
|
|
49
|
+
}, [client, runId, token]);
|
|
50
|
+
useEffect(() => {
|
|
51
|
+
if (enabled) {
|
|
52
|
+
void fetchAll();
|
|
53
|
+
}
|
|
54
|
+
}, [enabled, fetchAll]);
|
|
55
|
+
return {
|
|
56
|
+
run,
|
|
57
|
+
pages,
|
|
58
|
+
testCases,
|
|
59
|
+
testRuns,
|
|
60
|
+
issues,
|
|
61
|
+
personas,
|
|
62
|
+
components,
|
|
63
|
+
isLoading,
|
|
64
|
+
error,
|
|
65
|
+
counts: {
|
|
66
|
+
pages: pages.length,
|
|
67
|
+
testCases: testCases.length,
|
|
68
|
+
testRuns: testRuns.length,
|
|
69
|
+
issues: issues.length,
|
|
70
|
+
personas: personas.length,
|
|
71
|
+
components: components.length,
|
|
72
|
+
},
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=useRunManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRunManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useRunManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { NetworkClient } from '@sudobility/types';
|
|
2
|
+
import type { CreateScanRequest } from '@sudobility/testomniac_types';
|
|
3
|
+
interface UseScanManagerConfig {
|
|
4
|
+
networkClient: NetworkClient;
|
|
5
|
+
baseUrl: string;
|
|
6
|
+
}
|
|
7
|
+
export declare function useScanManager(config: UseScanManagerConfig): {
|
|
8
|
+
startScan: (data: CreateScanRequest) => Promise<import("@sudobility/types").BaseResponse<import("@sudobility/testomniac_types").CreateScanResponse>>;
|
|
9
|
+
isSubmitting: boolean;
|
|
10
|
+
submitError: Error | null;
|
|
11
|
+
runId: number | null;
|
|
12
|
+
phase: string;
|
|
13
|
+
pagesFound: number;
|
|
14
|
+
pageStatesFound: number;
|
|
15
|
+
actionsCompleted: number;
|
|
16
|
+
actionsRemaining: number;
|
|
17
|
+
issuesFound: number;
|
|
18
|
+
latestScreenshotUrl: string | null;
|
|
19
|
+
currentPageUrl: string | null;
|
|
20
|
+
events: import("@sudobility/testomniac_types").RunStreamEvent[];
|
|
21
|
+
isComplete: boolean;
|
|
22
|
+
error: string | null;
|
|
23
|
+
handleEvent: (event: import("@sudobility/testomniac_types").RunStreamEvent) => void;
|
|
24
|
+
reset: () => void;
|
|
25
|
+
};
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=useScanManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useScanManager.d.ts","sourceRoot":"","sources":["../../../src/business/hooks/useScanManager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAItE,UAAU,oBAAoB;IAC5B,aAAa,EAAE,aAAa,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,oBAAoB;sBAY1C,iBAAiB;;;;;;;;;;;;;;;;;EAyCjC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { useCallback, useMemo, useState } from 'react';
|
|
2
|
+
import { TestomniacClient } from '@sudobility/testomniac_client';
|
|
3
|
+
import { useScanProgressStore } from '../stores/scanProgressStore';
|
|
4
|
+
export function useScanManager(config) {
|
|
5
|
+
const { networkClient, baseUrl } = config;
|
|
6
|
+
const [isSubmitting, setIsSubmitting] = useState(false);
|
|
7
|
+
const [submitError, setSubmitError] = useState(null);
|
|
8
|
+
const store = useScanProgressStore();
|
|
9
|
+
const client = useMemo(() => new TestomniacClient({ networkClient, baseUrl }), [networkClient, baseUrl]);
|
|
10
|
+
const startScan = useCallback(async (data) => {
|
|
11
|
+
store.reset();
|
|
12
|
+
setIsSubmitting(true);
|
|
13
|
+
setSubmitError(null);
|
|
14
|
+
try {
|
|
15
|
+
const response = await client.submitScan(data);
|
|
16
|
+
if (response.success && response.data?.runId) {
|
|
17
|
+
store.setRunId(response.data.runId);
|
|
18
|
+
}
|
|
19
|
+
return response;
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
const error = err instanceof Error ? err : new Error('Failed to submit scan');
|
|
23
|
+
setSubmitError(error);
|
|
24
|
+
throw error;
|
|
25
|
+
}
|
|
26
|
+
finally {
|
|
27
|
+
setIsSubmitting(false);
|
|
28
|
+
}
|
|
29
|
+
}, [client, store]);
|
|
30
|
+
return {
|
|
31
|
+
startScan,
|
|
32
|
+
isSubmitting,
|
|
33
|
+
submitError,
|
|
34
|
+
runId: store.runId,
|
|
35
|
+
phase: store.phase,
|
|
36
|
+
pagesFound: store.pagesFound,
|
|
37
|
+
pageStatesFound: store.pageStatesFound,
|
|
38
|
+
actionsCompleted: store.actionsCompleted,
|
|
39
|
+
actionsRemaining: store.actionsRemaining,
|
|
40
|
+
issuesFound: store.issuesFound,
|
|
41
|
+
latestScreenshotUrl: store.latestScreenshotUrl,
|
|
42
|
+
currentPageUrl: store.currentPageUrl,
|
|
43
|
+
events: store.events,
|
|
44
|
+
isComplete: store.isComplete,
|
|
45
|
+
error: store.error,
|
|
46
|
+
handleEvent: store.handleEvent,
|
|
47
|
+
reset: store.reset,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=useScanManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useScanManager.js","sourceRoot":"","sources":["../../../src/business/hooks/useScanManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAGvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAOnE,MAAM,UAAU,cAAc,CAAC,MAA4B;IACzD,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC;IAC1C,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAe,IAAI,CAAC,CAAC;IACnE,MAAM,KAAK,GAAG,oBAAoB,EAAE,CAAC;IAErC,MAAM,MAAM,GAAG,OAAO,CACpB,GAAG,EAAE,CAAC,IAAI,gBAAgB,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EACtD,CAAC,aAAa,EAAE,OAAO,CAAC,CACzB,CAAC;IAEF,MAAM,SAAS,GAAG,WAAW,CAC3B,KAAK,EAAE,IAAuB,EAAE,EAAE;QAChC,KAAK,CAAC,KAAK,EAAE,CAAC;QACd,eAAe,CAAC,IAAI,CAAC,CAAC;QACtB,cAAc,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC/C,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC;gBAC7C,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACtC,CAAC;YACD,OAAO,QAAQ,CAAC;QAClB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,KAAK,GACT,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;YAClE,cAAc,CAAC,KAAK,CAAC,CAAC;YACtB,MAAM,KAAK,CAAC;QACd,CAAC;gBAAS,CAAC;YACT,eAAe,CAAC,KAAK,CAAC,CAAC;QACzB,CAAC;IACH,CAAC,EACD,CAAC,MAAM,EAAE,KAAK,CAAC,CAChB,CAAC;IAEF,OAAO;QACL,SAAS;QACT,YAAY;QACZ,WAAW;QACX,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;QACxC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;QACxC,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;QAC9C,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,KAAK,EAAE,KAAK,CAAC,KAAK;KACnB,CAAC;AACJ,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export { useScanProgressStore } from './scanProgressStore';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export { useScanProgressStore } from './scanProgressStore';
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/business/stores/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { RunStreamEvent } from '@sudobility/testomniac_types';
|
|
2
|
+
interface ScanProgressState {
|
|
3
|
+
runId: number | null;
|
|
4
|
+
phase: string;
|
|
5
|
+
pagesFound: number;
|
|
6
|
+
pageStatesFound: number;
|
|
7
|
+
actionsCompleted: number;
|
|
8
|
+
actionsRemaining: number;
|
|
9
|
+
issuesFound: number;
|
|
10
|
+
latestScreenshotUrl: string | null;
|
|
11
|
+
currentPageUrl: string | null;
|
|
12
|
+
events: RunStreamEvent[];
|
|
13
|
+
isComplete: boolean;
|
|
14
|
+
error: string | null;
|
|
15
|
+
setRunId: (runId: number) => void;
|
|
16
|
+
handleEvent: (event: RunStreamEvent) => void;
|
|
17
|
+
reset: () => void;
|
|
18
|
+
setError: (error: string | null) => void;
|
|
19
|
+
}
|
|
20
|
+
export declare const useScanProgressStore: import("zustand").UseBoundStore<import("zustand").StoreApi<ScanProgressState>>;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=scanProgressStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanProgressStore.d.ts","sourceRoot":"","sources":["../../../src/business/stores/scanProgressStore.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAEnE,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,MAAM,EAAE,cAAc,EAAE,CAAC;IACzB,UAAU,EAAE,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAGrB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,WAAW,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;IAC7C,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;CAC1C;AAiBD,eAAO,MAAM,oBAAoB,gFA+D9B,CAAC"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { create } from 'zustand';
|
|
2
|
+
const initialState = {
|
|
3
|
+
runId: null,
|
|
4
|
+
phase: 'pending',
|
|
5
|
+
pagesFound: 0,
|
|
6
|
+
pageStatesFound: 0,
|
|
7
|
+
actionsCompleted: 0,
|
|
8
|
+
actionsRemaining: 0,
|
|
9
|
+
issuesFound: 0,
|
|
10
|
+
latestScreenshotUrl: null,
|
|
11
|
+
currentPageUrl: null,
|
|
12
|
+
events: [],
|
|
13
|
+
isComplete: false,
|
|
14
|
+
error: null,
|
|
15
|
+
};
|
|
16
|
+
export const useScanProgressStore = create(set => ({
|
|
17
|
+
...initialState,
|
|
18
|
+
setRunId: runId => set({ runId }),
|
|
19
|
+
handleEvent: event => set(state => {
|
|
20
|
+
const events = [...state.events, event].slice(-100);
|
|
21
|
+
switch (event.type) {
|
|
22
|
+
case 'phase_changed':
|
|
23
|
+
return {
|
|
24
|
+
...state,
|
|
25
|
+
events,
|
|
26
|
+
phase: event.payload.phase,
|
|
27
|
+
};
|
|
28
|
+
case 'page_discovered':
|
|
29
|
+
return {
|
|
30
|
+
...state,
|
|
31
|
+
events,
|
|
32
|
+
pagesFound: state.pagesFound + 1,
|
|
33
|
+
currentPageUrl: event.payload.url,
|
|
34
|
+
};
|
|
35
|
+
case 'page_state_created':
|
|
36
|
+
return {
|
|
37
|
+
...state,
|
|
38
|
+
events,
|
|
39
|
+
pageStatesFound: state.pageStatesFound + 1,
|
|
40
|
+
};
|
|
41
|
+
case 'action_completed':
|
|
42
|
+
return {
|
|
43
|
+
...state,
|
|
44
|
+
events,
|
|
45
|
+
actionsCompleted: state.actionsCompleted + 1,
|
|
46
|
+
};
|
|
47
|
+
case 'issue_detected':
|
|
48
|
+
return {
|
|
49
|
+
...state,
|
|
50
|
+
events,
|
|
51
|
+
issuesFound: state.issuesFound + 1,
|
|
52
|
+
};
|
|
53
|
+
case 'run_completed':
|
|
54
|
+
return {
|
|
55
|
+
...state,
|
|
56
|
+
events,
|
|
57
|
+
isComplete: true,
|
|
58
|
+
phase: 'completed',
|
|
59
|
+
};
|
|
60
|
+
case 'run_failed':
|
|
61
|
+
return {
|
|
62
|
+
...state,
|
|
63
|
+
events,
|
|
64
|
+
isComplete: true,
|
|
65
|
+
phase: 'failed',
|
|
66
|
+
error: event.payload.error,
|
|
67
|
+
};
|
|
68
|
+
default:
|
|
69
|
+
return { ...state, events };
|
|
70
|
+
}
|
|
71
|
+
}),
|
|
72
|
+
reset: () => set(initialState),
|
|
73
|
+
setError: error => set({ error }),
|
|
74
|
+
}));
|
|
75
|
+
//# sourceMappingURL=scanProgressStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanProgressStore.js","sourceRoot":"","sources":["../../../src/business/stores/scanProgressStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAwBjC,MAAM,YAAY,GAAG;IACnB,KAAK,EAAE,IAAqB;IAC5B,KAAK,EAAE,SAAS;IAChB,UAAU,EAAE,CAAC;IACb,eAAe,EAAE,CAAC;IAClB,gBAAgB,EAAE,CAAC;IACnB,gBAAgB,EAAE,CAAC;IACnB,WAAW,EAAE,CAAC;IACd,mBAAmB,EAAE,IAAqB;IAC1C,cAAc,EAAE,IAAqB;IACrC,MAAM,EAAE,EAAsB;IAC9B,UAAU,EAAE,KAAK;IACjB,KAAK,EAAE,IAAqB;CAC7B,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,MAAM,CAAoB,GAAG,CAAC,EAAE,CAAC,CAAC;IACpE,GAAG,YAAY;IAEf,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;IAEjC,WAAW,EAAE,KAAK,CAAC,EAAE,CACnB,GAAG,CAAC,KAAK,CAAC,EAAE;QACV,MAAM,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;QAEpD,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,KAAK,eAAe;gBAClB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,KAAe;iBACrC,CAAC;YACJ,KAAK,iBAAiB;gBACpB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,UAAU,EAAE,KAAK,CAAC,UAAU,GAAG,CAAC;oBAChC,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,GAAa;iBAC5C,CAAC;YACJ,KAAK,oBAAoB;gBACvB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,eAAe,EAAE,KAAK,CAAC,eAAe,GAAG,CAAC;iBAC3C,CAAC;YACJ,KAAK,kBAAkB;gBACrB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,GAAG,CAAC;iBAC7C,CAAC;YACJ,KAAK,gBAAgB;gBACnB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,WAAW,EAAE,KAAK,CAAC,WAAW,GAAG,CAAC;iBACnC,CAAC;YACJ,KAAK,eAAe;gBAClB,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,UAAU,EAAE,IAAI;oBAChB,KAAK,EAAE,WAAW;iBACnB,CAAC;YACJ,KAAK,YAAY;gBACf,OAAO;oBACL,GAAG,KAAK;oBACR,MAAM;oBACN,UAAU,EAAE,IAAI;oBAChB,KAAK,EAAE,QAAQ;oBACf,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,KAAe;iBACrC,CAAC;YACJ;gBACE,OAAO,EAAE,GAAG,KAAK,EAAE,MAAM,EAAE,CAAC;QAChC,CAAC;IACH,CAAC,CAAC;IAEJ,KAAK,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,YAAY,CAAC;IAC9B,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;CAClC,CAAC,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sudobility/testomniac_lib",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.23",
|
|
4
4
|
"description": "Testomniac business logic library with Zustand stores",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -42,7 +42,7 @@
|
|
|
42
42
|
},
|
|
43
43
|
"devDependencies": {
|
|
44
44
|
"@eslint/js": "^9.38.0",
|
|
45
|
-
"@sudobility/testomniac_client": "^0.0.
|
|
45
|
+
"@sudobility/testomniac_client": "^0.0.24",
|
|
46
46
|
"@sudobility/testomniac_types": "^0.0.21",
|
|
47
47
|
"@sudobility/types": "^1.9.61",
|
|
48
48
|
"@tanstack/react-query": "^5.90.5",
|