Merge branch 'main' into robertbrignull/data_narrow

This commit is contained in:
Robert
2023-07-28 09:51:27 +01:00
committed by GitHub
8 changed files with 60 additions and 3 deletions

View File

@@ -91,6 +91,8 @@ export function DataExtensionsEditor({
new Set(), new Set(),
); );
const [hideModeledApis, setHideModeledApis] = useState(true);
const [modeledMethods, setModeledMethods] = useState< const [modeledMethods, setModeledMethods] = useState<
Record<string, ModeledMethod> Record<string, ModeledMethod>
>(initialModeledMethods); >(initialModeledMethods);
@@ -252,6 +254,10 @@ export function DataExtensionsEditor({
}); });
}, [viewState?.mode]); }, [viewState?.mode]);
const onHideModeledApis = useCallback(() => {
setHideModeledApis((oldHideModeledApis) => !oldHideModeledApis);
}, []);
if (viewState === undefined || externalApiUsages.length === 0) { if (viewState === undefined || externalApiUsages.length === 0) {
return <LoadingContainer>Loading...</LoadingContainer>; return <LoadingContainer>Loading...</LoadingContainer>;
} }
@@ -292,7 +298,12 @@ export function DataExtensionsEditor({
</HeaderColumn> </HeaderColumn>
<HeaderSpacer /> <HeaderSpacer />
<HeaderColumn> <HeaderColumn>
<VSCodeCheckbox>Hide modeled APIs</VSCodeCheckbox> <VSCodeCheckbox
checked={hideModeledApis}
onChange={onHideModeledApis}
>
Hide modeled APIs
</VSCodeCheckbox>
</HeaderColumn> </HeaderColumn>
</HeaderContainer> </HeaderContainer>
@@ -320,6 +331,7 @@ export function DataExtensionsEditor({
modeledMethods={modeledMethods} modeledMethods={modeledMethods}
modifiedSignatures={modifiedSignatures} modifiedSignatures={modifiedSignatures}
viewState={viewState} viewState={viewState}
hideModeledApis={hideModeledApis}
onChange={onChange} onChange={onChange}
onSaveModelClick={onSaveModelClick} onSaveModelClick={onSaveModelClick}
onGenerateFromLlmClick={onGenerateFromLlmClick} onGenerateFromLlmClick={onGenerateFromLlmClick}

View File

@@ -73,6 +73,7 @@ type Props = {
modeledMethods: Record<string, ModeledMethod>; modeledMethods: Record<string, ModeledMethod>;
modifiedSignatures: Set<string>; modifiedSignatures: Set<string>;
viewState: DataExtensionEditorViewState; viewState: DataExtensionEditorViewState;
hideModeledApis: boolean;
onChange: ( onChange: (
modelName: string, modelName: string,
externalApiUsage: ExternalApiUsage, externalApiUsage: ExternalApiUsage,
@@ -97,6 +98,7 @@ export const LibraryRow = ({
modeledMethods, modeledMethods,
modifiedSignatures, modifiedSignatures,
viewState, viewState,
hideModeledApis,
onChange, onChange,
onSaveModelClick, onSaveModelClick,
onGenerateFromLlmClick, onGenerateFromLlmClick,
@@ -208,6 +210,7 @@ export const LibraryRow = ({
modeledMethods={modeledMethods} modeledMethods={modeledMethods}
modifiedSignatures={modifiedSignatures} modifiedSignatures={modifiedSignatures}
mode={viewState.mode} mode={viewState.mode}
hideModeledApis={hideModeledApis}
onChange={onChangeWithModelName} onChange={onChangeWithModelName}
/> />
<SectionDivider /> <SectionDivider />

View File

@@ -56,6 +56,7 @@ type Props = {
modeledMethod: ModeledMethod | undefined; modeledMethod: ModeledMethod | undefined;
methodIsUnsaved: boolean; methodIsUnsaved: boolean;
mode: Mode; mode: Mode;
hideModeledApis: boolean;
onChange: ( onChange: (
externalApiUsage: ExternalApiUsage, externalApiUsage: ExternalApiUsage,
modeledMethod: ModeledMethod, modeledMethod: ModeledMethod,
@@ -63,7 +64,8 @@ type Props = {
}; };
export const MethodRow = (props: Props) => { export const MethodRow = (props: Props) => {
const { externalApiUsage, modeledMethod, methodIsUnsaved } = props; const { externalApiUsage, modeledMethod, methodIsUnsaved, hideModeledApis } =
props;
const methodCanBeModeled = const methodCanBeModeled =
!externalApiUsage.supported || !externalApiUsage.supported ||
@@ -72,6 +74,8 @@ export const MethodRow = (props: Props) => {
if (methodCanBeModeled) { if (methodCanBeModeled) {
return <ModelableMethodRow {...props} />; return <ModelableMethodRow {...props} />;
} else if (hideModeledApis) {
return null;
} else { } else {
return <UnmodelableMethodRow {...props} />; return <UnmodelableMethodRow {...props} />;
} }

View File

@@ -16,6 +16,7 @@ type Props = {
modeledMethods: Record<string, ModeledMethod>; modeledMethods: Record<string, ModeledMethod>;
modifiedSignatures: Set<string>; modifiedSignatures: Set<string>;
mode: Mode; mode: Mode;
hideModeledApis: boolean;
onChange: ( onChange: (
externalApiUsage: ExternalApiUsage, externalApiUsage: ExternalApiUsage,
modeledMethod: ModeledMethod, modeledMethod: ModeledMethod,
@@ -27,6 +28,7 @@ export const ModeledMethodDataGrid = ({
modeledMethods, modeledMethods,
modifiedSignatures, modifiedSignatures,
mode, mode,
hideModeledApis,
onChange, onChange,
}: Props) => { }: Props) => {
const sortedExternalApiUsages = useMemo( const sortedExternalApiUsages = useMemo(
@@ -60,6 +62,7 @@ export const ModeledMethodDataGrid = ({
modeledMethod={modeledMethods[externalApiUsage.signature]} modeledMethod={modeledMethods[externalApiUsage.signature]}
methodIsUnsaved={modifiedSignatures.has(externalApiUsage.signature)} methodIsUnsaved={modifiedSignatures.has(externalApiUsage.signature)}
mode={mode} mode={mode}
hideModeledApis={hideModeledApis}
onChange={onChange} onChange={onChange}
/> />
))} ))}

View File

@@ -15,6 +15,7 @@ type Props = {
modeledMethods: Record<string, ModeledMethod>; modeledMethods: Record<string, ModeledMethod>;
modifiedSignatures: Set<string>; modifiedSignatures: Set<string>;
viewState: DataExtensionEditorViewState; viewState: DataExtensionEditorViewState;
hideModeledApis: boolean;
onChange: ( onChange: (
modelName: string, modelName: string,
externalApiUsage: ExternalApiUsage, externalApiUsage: ExternalApiUsage,
@@ -41,6 +42,7 @@ export const ModeledMethodsList = ({
modeledMethods, modeledMethods,
modifiedSignatures, modifiedSignatures,
viewState, viewState,
hideModeledApis,
onChange, onChange,
onSaveModelClick, onSaveModelClick,
onGenerateFromLlmClick, onGenerateFromLlmClick,
@@ -83,6 +85,7 @@ export const ModeledMethodsList = ({
modeledMethods={modeledMethods} modeledMethods={modeledMethods}
modifiedSignatures={modifiedSignatures} modifiedSignatures={modifiedSignatures}
viewState={viewState} viewState={viewState}
hideModeledApis={hideModeledApis}
onChange={onChange} onChange={onChange}
onSaveModelClick={onSaveModelClick} onSaveModelClick={onSaveModelClick}
onGenerateFromLlmClick={onGenerateFromLlmClick} onGenerateFromLlmClick={onGenerateFromLlmClick}

View File

@@ -1,5 +1,5 @@
[ [
"v2.14.0", "v2.14.1",
"v2.13.5", "v2.13.5",
"v2.12.7", "v2.12.7",
"v2.11.6", "v2.11.6",

View File

@@ -111,11 +111,20 @@ describeWithCodeQL()("using the legacy query server", () => {
let qs: qsClient.QueryServerClient; let qs: qsClient.QueryServerClient;
let cliServer: cli.CodeQLCliServer; let cliServer: cli.CodeQLCliServer;
let supportNewQueryServer = false;
beforeAll(async () => { beforeAll(async () => {
const extension = await getActivatedExtension(); const extension = await getActivatedExtension();
cliServer = extension.cliServer; cliServer = extension.cliServer;
cliServer.quiet = true; cliServer.quiet = true;
if (await cliServer.cliConstraints.supportsNewQueryServerForTests()) {
console.log(
"Skipping legacy-query tests: the CLI supports the new query server",
);
supportNewQueryServer = true;
}
qs = new QueryServerClient( qs = new QueryServerClient(
createMockApp({}), createMockApp({}),
{ {
@@ -145,10 +154,18 @@ describeWithCodeQL()("using the legacy query server", () => {
const parsedResults = new Checkpoint<void>(); const parsedResults = new Checkpoint<void>();
it("should register the database if necessary", async () => { it("should register the database if necessary", async () => {
if (supportNewQueryServer) {
return;
}
await qs.sendRequest(messages.registerDatabases, { databases: [db] }); await qs.sendRequest(messages.registerDatabases, { databases: [db] });
}); });
it(`should be able to compile query ${queryName}`, async () => { it(`should be able to compile query ${queryName}`, async () => {
if (supportNewQueryServer) {
return;
}
expect(existsSync(queryTestCase.queryPath)).toBe(true); expect(existsSync(queryTestCase.queryPath)).toBe(true);
try { try {
const qlProgram: messages.QlProgram = { const qlProgram: messages.QlProgram = {
@@ -188,6 +205,10 @@ describeWithCodeQL()("using the legacy query server", () => {
}); });
it(`should be able to run query ${queryName}`, async () => { it(`should be able to run query ${queryName}`, async () => {
if (supportNewQueryServer) {
return;
}
try { try {
await compilationSucceeded.done(); await compilationSucceeded.done();
const callbackId = qs.registerCallback((_res) => { const callbackId = qs.registerCallback((_res) => {
@@ -217,6 +238,10 @@ describeWithCodeQL()("using the legacy query server", () => {
const actualResultSets: ResultSets = {}; const actualResultSets: ResultSets = {};
it(`should be able to parse results of query ${queryName}`, async () => { it(`should be able to parse results of query ${queryName}`, async () => {
if (supportNewQueryServer) {
return;
}
await evaluationSucceeded.done(); await evaluationSucceeded.done();
const info = await cliServer.bqrsInfo(RESULTS_PATH); const info = await cliServer.bqrsInfo(RESULTS_PATH);
@@ -231,6 +256,10 @@ describeWithCodeQL()("using the legacy query server", () => {
}); });
it(`should have correct results for query ${queryName}`, async () => { it(`should have correct results for query ${queryName}`, async () => {
if (supportNewQueryServer) {
return;
}
await parsedResults.done(); await parsedResults.done();
expect(actualResultSets).not.toEqual({}); expect(actualResultSets).not.toEqual({});
expect(Object.keys(actualResultSets!).sort()).toEqual( expect(Object.keys(actualResultSets!).sort()).toEqual(

View File

@@ -114,6 +114,9 @@ describeWithCodeQL()("using the new query server", () => {
cliServer.quiet = true; cliServer.quiet = true;
if (!(await cliServer.cliConstraints.supportsNewQueryServerForTests())) { if (!(await cliServer.cliConstraints.supportsNewQueryServerForTests())) {
console.log(
"Skipping new-query tests: the CLI supports only the legacy query server",
);
supportNewQueryServer = false; supportNewQueryServer = false;
} }
qs = new QueryServerClient( qs = new QueryServerClient(