Skip to content

Commit

Permalink
enhance: use ArrayBuffer for dataset element contents
Browse files Browse the repository at this point in the history
Signed-off-by: Grant Linville <[email protected]>
  • Loading branch information
g-linville committed Oct 31, 2024
1 parent ea42fed commit 4b5c9d9
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 14 deletions.
25 changes: 19 additions & 6 deletions src/gptscript.ts
Original file line number Diff line number Diff line change
Expand Up @@ -415,7 +415,7 @@ export class GPTScript {
return JSON.parse(result) as Dataset
}

async addDatasetElement(workspaceID: string, datasetID: string, elementName: string, elementDescription: string, elementContent: string): Promise<DatasetElementMeta> {
async addDatasetElement(workspaceID: string, datasetID: string, elementName: string, elementDescription: string, elementContent: ArrayBuffer): Promise<DatasetElementMeta> {
if (workspaceID == "") {
workspaceID = process.env.GPTSCRIPT_WORKSPACE_ID ?? ""
}
Expand All @@ -425,7 +425,7 @@ export class GPTScript {
datasetID,
elementName: elementName,
elementDescription: elementDescription,
elementContent: elementContent
elementContent: Buffer.from(elementContent).toString("base64")
}),
workspaceID: workspaceID,
datasetToolRepo: this.opts.DatasetToolRepo ?? "",
Expand All @@ -439,8 +439,16 @@ export class GPTScript {
workspaceID = process.env.GPTSCRIPT_WORKSPACE_ID ?? ""
}

const serializableElements = elements.map(e => {
return {
name: e.name,
description: e.description,
contents: Buffer.from(e.contents).toString("base64")
}
})

return await this.runBasicCommand("datasets/add-elements", {
input: JSON.stringify({datasetID, elements}),
input: JSON.stringify({datasetID, elements: serializableElements}),
workspaceID: workspaceID,
datasetToolRepo: this.opts.DatasetToolRepo ?? "",
env: this.opts.Env,
Expand All @@ -452,7 +460,6 @@ export class GPTScript {
workspaceID = process.env.GPTSCRIPT_WORKSPACE_ID ?? ""
}


const result = await this.runBasicCommand("datasets/list-elements", {
input: JSON.stringify({datasetID}),
workspaceID: workspaceID,
Expand All @@ -473,7 +480,13 @@ export class GPTScript {
datasetToolRepo: this.opts.DatasetToolRepo ?? "",
env: this.opts.Env
})
return JSON.parse(result) as DatasetElement

const element = JSON.parse(result)
return {
name: element.name,
description: element.description,
contents: Buffer.from(element.contents, "base64")
}
}

async createWorkspace(providerType: string, ...fromWorkspaces: string[]): Promise<string> {
Expand Down Expand Up @@ -1309,7 +1322,7 @@ export interface DatasetElementMeta {
export interface DatasetElement {
name: string
description: string
contents: string
contents: ArrayBuffer
}

export interface DatasetMeta {
Expand Down
16 changes: 8 additions & 8 deletions tests/gptscript.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -911,7 +911,7 @@ describe("gptscript module", () => {
datasetID,
"element1",
"",
"this is element 1 contents"
Buffer.from("this is element 1 contents")
)
expect(e1.name).toEqual("element1")
expect(e1.description).toEqual("")
Expand All @@ -921,7 +921,7 @@ describe("gptscript module", () => {
datasetID,
"element2",
"a description",
"this is element 2 contents"
Buffer.from("this is element 2 contents")
)
expect(e2.name).toEqual("element2")
expect(e2.description).toEqual("a description")
Expand All @@ -938,12 +938,12 @@ describe("gptscript module", () => {
{
name: "element3",
description: "a description",
contents: "this is element 3 contents"
contents: Buffer.from("this is element 3 contents")
},
{
name: "element4",
description: "a description",
contents: "this is element 4 contents"
contents: Buffer.from("this is element 4 contents")
}
]
)
Expand All @@ -956,22 +956,22 @@ describe("gptscript module", () => {
const e1 = await g.getDatasetElement(workspaceID, datasetID, "element1")
expect(e1.name).toEqual("element1")
expect(e1.description).toBeUndefined()
expect(e1.contents).toEqual("this is element 1 contents")
expect(e1.contents).toEqual(Buffer.from("this is element 1 contents"))

const e2 = await g.getDatasetElement(workspaceID, datasetID, "element2")
expect(e2.name).toEqual("element2")
expect(e2.description).toEqual("a description")
expect(e2.contents).toEqual("this is element 2 contents")
expect(e2.contents).toEqual(Buffer.from("this is element 2 contents"))

const e3 = await g.getDatasetElement(workspaceID, datasetID, "element3")
expect(e3.name).toEqual("element3")
expect(e3.description).toEqual("a description")
expect(e3.contents).toEqual("this is element 3 contents")
expect(e3.contents).toEqual(Buffer.from("this is element 3 contents"))

const e4 = await g.getDatasetElement(workspaceID, datasetID, "element4")
expect(e4.name).toEqual("element4")
expect(e4.description).toEqual("a description")
expect(e4.contents).toEqual("this is element 4 contents")
expect(e4.contents).toEqual(Buffer.from("this is element 4 contents"))
} catch (e) {
throw new Error("failed to get elements: " + e)
}
Expand Down

0 comments on commit 4b5c9d9

Please sign in to comment.