Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

code cleanup #597

Merged
merged 1 commit into from
Jun 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion OpenAI.Playground/ExtensionsAndHelpers/ConsoleExtensions.cs
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,9 @@ public static void WriteError(Error? error)
{
if (error == null)
{
throw new Exception("Unknown Error");
throw new("Unknown Error");
}

WriteLine($"{error.Code}: {error.Message}", ConsoleColor.Red);
}
}
4 changes: 1 addition & 3 deletions OpenAI.Playground/Program.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,8 @@
using OpenAI.Extensions;
using OpenAI.Interfaces;
using OpenAI.Playground.TestHelpers;
using OpenAI.Playground.TestHelpers.AssistantHelpers;

var builder = new ConfigurationBuilder().AddJsonFile("ApiSettings.json")
.AddUserSecrets<Program>();
var builder = new ConfigurationBuilder().AddJsonFile("ApiSettings.json").AddUserSecrets<Program>();

IConfiguration configuration = builder.Build();
var serviceCollection = new ServiceCollection();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@
using OpenAI.Playground.ExtensionsAndHelpers;

namespace OpenAI.Playground.TestHelpers.AssistantHelpers;
internal static partial class AssistantTestHelper

internal static partial class AssistantTestHelper
{
internal static class BasicsTestHelper
{
Expand Down Expand Up @@ -128,9 +129,7 @@ public static async Task ModifyAssistantTask(IOpenAIService openAI)

if (result.Successful)
{
if (result is { Name: newName, Instructions: newInstructions } && result.Tools.First()
.Type == ToolDefinition.DefineFileSearch()
.Type)
if (result is { Name: newName, Instructions: newInstructions } && result.Tools.First().Type == ToolDefinition.DefineFileSearch().Type)
{
ConsoleExtensions.WriteLine("Modify Assistant Test is successful.", ConsoleColor.Green);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,16 +27,14 @@ public static async Task RunAssistantApiTest(IOpenAIService sdk)

#region Create assistant

var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway"))
.Validate()
.Build();
var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway")).Validate().Build();

ConsoleExtensions.WriteLine("Assistant Create Test:", ConsoleColor.DarkCyan);
var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new AssistantCreateRequest
var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new()
{
Instructions = "You are a professional assistant who provides company information. Company-related data comes from uploaded questions and does not provide vague answers, only clear answers.",
Name = "Qicha",
Tools = new List<ToolDefinition>() { ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func) },
Tools = new() { ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func) },
Model = Models.Gpt_3_5_Turbo_1106
});
if (assistantResult.Successful)
Expand Down Expand Up @@ -75,7 +73,7 @@ public static async Task RunAssistantApiTest(IOpenAIService sdk)
#region // Assistant modify

ConsoleExtensions.WriteLine("Assistant modify:", ConsoleColor.DarkCyan);
var asstResult = await sdk.Beta.Assistants.AssistantModify(assistantId, new AssistantModifyRequest()
var asstResult = await sdk.Beta.Assistants.AssistantModify(assistantId, new()
{
Name = "Qicha rename"
});
Expand Down Expand Up @@ -161,17 +159,15 @@ public static async Task RunHowAssistantsWorkTest(IOpenAIService sdk)

#region //create assistants

var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway"))
.Validate()
.Build();
var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway")).Validate().Build();

ConsoleExtensions.WriteLine("Assistant Create Test:", ConsoleColor.DarkCyan);
var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new AssistantCreateRequest
var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new()
{
Instructions = "You are a professional assistant who provides company information. Company-related data comes from uploaded questions and does not provide vague answers, only clear answers.",
Name = "Qicha",
Model = Models.Gpt_3_5_Turbo_1106,
Tools = new List<ToolDefinition>() { ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func) },
Tools = [ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func)]
});

if (assistantResult.Successful)
Expand Down Expand Up @@ -211,16 +207,19 @@ public static async Task RunHowAssistantsWorkTest(IOpenAIService sdk)
#region //create thread message

ConsoleExtensions.WriteLine("Message Create Test:", ConsoleColor.DarkCyan);
var messageResult = await sdk.Beta.Messages.CreateMessage(threadId, new MessageCreateRequest
var messageResult = await sdk.Beta.Messages.CreateMessage(threadId, new()
{
Role = StaticValues.AssistantsStatics.MessageStatics.Roles.User,
Content =new("Where is Zhejiang Jiacheng Supply Chain Co., LTD."),
Content = new("Where is Zhejiang Jiacheng Supply Chain Co., LTD."),
// Tools must be specified for Attachments
Attachments = [new()
{
FileId = uploadFileId,
Tools = [ ToolDefinition.DefineFileSearch() ]
}]
Attachments =
[
new()
{
FileId = uploadFileId,
Tools = [ToolDefinition.DefineFileSearch()]
}
]
});

if (messageResult.Successful)
Expand All @@ -240,7 +239,7 @@ public static async Task RunHowAssistantsWorkTest(IOpenAIService sdk)
#region //create run

ConsoleExtensions.WriteLine("Run Create Test:", ConsoleColor.DarkCyan);
var runResult = await sdk.Beta.Runs.RunCreate(threadId, new RunCreateRequest()
var runResult = await sdk.Beta.Runs.RunCreate(threadId, new()
{
AssistantId = assistantId
});
Expand Down Expand Up @@ -305,7 +304,7 @@ public static async Task RunHowAssistantsWorkTest(IOpenAIService sdk)
//All outputs must be submitted in a single request.
if (toolOutputs.Any())
{
await sdk.Beta.Runs.RunSubmitToolOutputs(threadId, runId, new SubmitToolOutputsToRunRequest()
await sdk.Beta.Runs.RunSubmitToolOutputs(threadId, runId, new()
{
ToolOutputs = toolOutputs
});
Expand All @@ -332,8 +331,7 @@ public static async Task RunHowAssistantsWorkTest(IOpenAIService sdk)
{
var msgRespList = messageListResult.Data;
var ask = msgRespList?.FirstOrDefault(msg => msg.Role == StaticValues.AssistantsStatics.MessageStatics.Roles.User);
var replys = msgRespList?.Where(msg => msg.CreatedAt > ask?.CreatedAt && msg.Role == StaticValues.AssistantsStatics.MessageStatics.Roles.Assistant)
.ToList() ?? new List<MessageResponse>();
var replys = msgRespList?.Where(msg => msg.CreatedAt > ask?.CreatedAt && msg.Role == StaticValues.AssistantsStatics.MessageStatics.Roles.Assistant).ToList() ?? new List<MessageResponse>();
ConsoleExtensions.WriteLine(replys.ToJson());
}
else
Expand Down
18 changes: 7 additions & 11 deletions OpenAI.Playground/TestHelpers/AssistantHelpers/RunTestHelper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ public static async Task RunThreadAndRunTests(IOpenAIService openAI)
ConsoleExtensions.WriteLine("Run Thread and Run Testing is starting:", ConsoleColor.Blue);
await CreateThreadAndRun(openAI);
}


public static async Task CreateRunTest(IOpenAIService openAI)
{
Expand Down Expand Up @@ -185,7 +185,6 @@ public static async Task CreateRunAsStreamTest(IOpenAIService openAI)
ConsoleExtensions.WriteError(run.Error);
}
}

}

public static async Task CreateToolRunTest(IOpenAIService openAI)
Expand Down Expand Up @@ -404,8 +403,7 @@ public static async Task SubmitToolOutputsToRunTest(IOpenAIService openAI)
[
new()
{
ToolCallId = retrieveResult.RequiredAction!.SubmitToolOutputs.ToolCalls.First()
.Id,
ToolCallId = retrieveResult.RequiredAction!.SubmitToolOutputs.ToolCalls.First().Id,
Output = "70 degrees and sunny."
}
]
Expand Down Expand Up @@ -442,8 +440,7 @@ public static async Task SubmitToolOutputsAsStreamToRunTest(IOpenAIService openA
[
new()
{
ToolCallId = retrieveResult.RequiredAction!.SubmitToolOutputs.ToolCalls.First()
.Id,
ToolCallId = retrieveResult.RequiredAction!.SubmitToolOutputs.ToolCalls.First().Id,
Output = "70 degrees and sunny."
}
]
Expand Down Expand Up @@ -485,6 +482,7 @@ public static async Task CancelRunTest(IOpenAIService openAI)
{
CreatedAssistantId = assistantResult.Id;
}

var createRunResult = await openAI.Beta.Runs.RunCreate(createThreadResult.Id, new() { AssistantId = assistantResult.Id });
var result = await openAI.Beta.Runs.RunCancel(createThreadResult.Id, createRunResult.Id);

Expand Down Expand Up @@ -565,8 +563,7 @@ public static async Task RetrieveRunStepTest(IOpenAIService openAI)
}

var resultStepsList = await openAI.Beta.RunSteps.RunStepsList(CreatedThreadId, CreatedRunId);
var result = await openAI.Beta.RunSteps.RunStepRetrieve(CreatedThreadId, CreatedRunId, resultStepsList.Data!.First()
.Id);
var result = await openAI.Beta.RunSteps.RunStepRetrieve(CreatedThreadId, CreatedRunId, resultStepsList.Data!.First().Id);
if (result.Successful)
{
ConsoleExtensions.WriteLine("Retrieve Run Step Test is successful.", ConsoleColor.Green);
Expand Down Expand Up @@ -640,7 +637,7 @@ public static async Task CreateThreadAndRunAsStream(IOpenAIService sdk)
]
}
});

await foreach (var run in runResult)
{
if (run.Successful)
Expand All @@ -659,9 +656,8 @@ public static async Task CreateThreadAndRunAsStream(IOpenAIService sdk)
ConsoleExtensions.WriteError(run.Error);
}
}
ConsoleExtensions.WriteLine("Create Thread and Run As Stream Test is successful.", ConsoleColor.Green);


ConsoleExtensions.WriteLine("Create Thread and Run As Stream Test is successful.", ConsoleColor.Green);
}

public static async Task Cleanup(IOpenAIService sdk)
Expand Down
39 changes: 18 additions & 21 deletions OpenAI.Playground/TestHelpers/AssistantHelpers/RunTestHelper2.cs
Original file line number Diff line number Diff line change
Expand Up @@ -19,19 +19,17 @@ public static async Task RunRunCreateTest(IOpenAIService sdk)
ConsoleExtensions.WriteLine("Run Create Test:", ConsoleColor.DarkCyan);
var threadResult = await sdk.Beta.Threads.ThreadCreate();
var threadId = threadResult.Id;
var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway"))
.Validate()
.Build();
var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new AssistantCreateRequest
var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway")).Validate().Build();
var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new()
{
Instructions = "You are a professional assistant who provides company information. Company-related data comes from uploaded questions and does not provide vague answers, only clear answers.",
Name = "Qicha",
Tools = new List<ToolDefinition>() { ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func) },
Tools = new() { ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func) },
Model = Models.Gpt_3_5_Turbo_1106
});
var runResult = await sdk.Beta.Runs.RunCreate(threadId, new RunCreateRequest()
var runResult = await sdk.Beta.Runs.RunCreate(threadId, new()
{
AssistantId = assistantResult.Id,
AssistantId = assistantResult.Id
});
if (runResult.Successful)
{
Expand All @@ -41,7 +39,7 @@ public static async Task RunRunCreateTest(IOpenAIService sdk)
{
if (runResult.Error == null)
{
throw new Exception("Unknown Error");
throw new("Unknown Error");
}

ConsoleExtensions.WriteLine($"{runResult.Error.Code}: {runResult.Error.Message}");
Expand Down Expand Up @@ -87,7 +85,7 @@ public static async Task RunRunCreateTest(IOpenAIService sdk)
attemptCount++;
if (attemptCount >= maxAttempts)
{
throw new Exception("The maximum number of attempts has been reached.");
throw new("The maximum number of attempts has been reached.");
}
} while (!doneStatusList.Contains(runStatus));
}
Expand All @@ -104,18 +102,17 @@ public static async Task RunRunCancelTest(IOpenAIService sdk)
ConsoleExtensions.WriteLine("Run cancel Testing is starting:", ConsoleColor.Cyan);
var threadResult = await sdk.Beta.Threads.ThreadCreate();
var threadId = threadResult.Id;
var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway"))
.Validate()
.Build(); var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new AssistantCreateRequest
{
Instructions = "You are a professional assistant who provides company information. Company-related data comes from uploaded questions and does not provide vague answers, only clear answers.",
Name = "Qicha",
Tools = new List<ToolDefinition>() { ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func) },
Model = Models.Gpt_3_5_Turbo_1106
});
var runCreateResult = await sdk.Beta.Runs.RunCreate(threadId, new RunCreateRequest()
var func = new FunctionDefinitionBuilder("get_corp_location", "get location of corp").AddParameter("name", PropertyDefinition.DefineString("company name, e.g. Betterway")).Validate().Build();
var assistantResult = await sdk.Beta.Assistants.AssistantCreate(new()
{
Instructions = "You are a professional assistant who provides company information. Company-related data comes from uploaded questions and does not provide vague answers, only clear answers.",
Name = "Qicha",
Tools = new() { ToolDefinition.DefineCodeInterpreter(), ToolDefinition.DefineFileSearch(), ToolDefinition.DefineFunction(func) },
Model = Models.Gpt_3_5_Turbo_1106
});
var runCreateResult = await sdk.Beta.Runs.RunCreate(threadId, new()
{
AssistantId = assistantResult.Id,
AssistantId = assistantResult.Id
});

ConsoleExtensions.WriteLine("Run Cancel Test:", ConsoleColor.DarkCyan);
Expand All @@ -128,7 +125,7 @@ public static async Task RunRunCancelTest(IOpenAIService sdk)
{
if (runResult.Error == null)
{
throw new Exception("Unknown Error");
throw new("Unknown Error");
}

ConsoleExtensions.WriteLine($"{runResult.Error.Code}: {runResult.Error.Message}");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -219,7 +219,7 @@ public static async Task CreateVectorFile(IOpenAIService openAI)
CreatedFileId1 = uploadFilesResponse.Id;
var result = await openAI.Beta.VectorStoreFiles.CreateVectorStoreFile(CreatedVectorId, new()
{
FileId = CreatedFileId1,
FileId = CreatedFileId1
});

if (result.Successful)
Expand Down Expand Up @@ -523,4 +523,4 @@ private static async Task Cleanup(IOpenAIService sdk)
}
}
}
}
}
Loading
Loading