Merge branch 'main' into robertbrignull/data_narrow
This commit is contained in:
@@ -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}
|
||||||
|
|||||||
@@ -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 />
|
||||||
|
|||||||
@@ -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} />;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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}
|
||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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",
|
||||||
|
|||||||
@@ -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(
|
||||||
|
|||||||
@@ -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(
|
||||||
|
|||||||
Reference in New Issue
Block a user