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

Refactor to put the AZ CLI related calls behind an interface #259

Open
wants to merge 57 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
0b59c87
Basic command telemetry
ralph-msft Jan 11, 2024
cbe5d95
Checkpoint of making telemetry configurable
ralph-msft Feb 7, 2024
4ec3f67
More funnel telemetry
ralph-msft Feb 7, 2024
3013cc0
Fix yaml typos
ralph-msft Feb 7, 2024
6727b4b
Work around supply chain analysis issue
ralph-msft Feb 7, 2024
6c2234a
Try to work around odd windows only error message
ralph-msft Feb 7, 2024
5e867cf
Move telemetry override into separate library for easier maintenance
ralph-msft Feb 7, 2024
3eb93a0
Attempt to correct capitalization of NuGet.Config file
ralph-msft Feb 7, 2024
2593466
Use Nuget restore instead to force use of config file
ralph-msft Feb 7, 2024
5ed51fe
Yet another attempt to work around restore issue
ralph-msft Feb 7, 2024
c88d55a
Add NuGet authenticate step to build
ralph-msft Feb 7, 2024
f26d469
Switch to different NuGet source that has the standard Nuget upstream
ralph-msft Feb 7, 2024
61cb0a5
Remove now unneeded file
ralph-msft Feb 7, 2024
8f799cf
Make Nuget signing optional
ralph-msft Feb 7, 2024
58afd78
Try another way to make Nuget signing step optional
ralph-msft Feb 7, 2024
4c190e0
Simplify syntax
ralph-msft Feb 7, 2024
b759717
Log what build variables we are setting
ralph-msft Feb 7, 2024
005fd86
Make telemetry type a parameter that can be set when scheduling builds
ralph-msft Feb 7, 2024
549503e
Fix typo
ralph-msft Feb 7, 2024
665f15c
Clean up secret variable naming in library
ralph-msft Feb 7, 2024
4db6da7
Fix typo
ralph-msft Feb 7, 2024
44cf614
Add back missing variable group use
ralph-msft Feb 7, 2024
31c456d
Fix more typos
ralph-msft Feb 7, 2024
6ba0920
Improve dev build versioning
ralph-msft Feb 8, 2024
c118d15
Try another naming approach
ralph-msft Feb 8, 2024
b57b2d6
Try to fix parser errors
ralph-msft Feb 8, 2024
9d198e2
Yet another attempt
ralph-msft Feb 8, 2024
d329659
revert some changes
ralph-msft Feb 8, 2024
524d977
Remove launch settings
ralph-msft Feb 8, 2024
760b4dc
Move configurtion update to separate template file for easier mainten…
ralph-msft Feb 8, 2024
10e7292
Revert "Move configurtion update to separate template file for easier…
ralph-msft Feb 8, 2024
b2d6f3e
Merge remote-tracking branch 'origin/main' into feature/telemetry
ralph-msft Feb 9, 2024
94b74fe
Add missing Nuget authenticate step for test stage
ralph-msft Feb 9, 2024
fff5077
Merge remote-tracking branch 'origin/main' into feature/telemetry
ralph-msft Feb 13, 2024
a939526
Dump nuget sources to debug build failure
ralph-msft Feb 14, 2024
33161c2
Revert "Dump nuget sources to debug build failure"
ralph-msft Feb 14, 2024
f7cc819
Add missing Nuget authenticate step
ralph-msft Feb 14, 2024
80cf0a7
Add markdown flow charts
ralph-msft Mar 6, 2024
21b9099
JSON deserialization improvements
ralph-msft Mar 6, 2024
b26d2c1
Miscellaenous bug fixes and tweaks:
ralph-msft Mar 6, 2024
34d3288
Merge remote-tracking branch 'origin/main' into feature/telemetry
ralph-msft Mar 7, 2024
cec2476
Telemetry check point
ralph-msft Mar 8, 2024
e97abc3
Checkpoint saved configuration verification has telemetry event
ralph-msft Mar 8, 2024
29e036f
Cleanup and bug fixes
ralph-msft Mar 9, 2024
e216687
Checkpoint of refactor into interfaces
ralph-msft Mar 22, 2024
b6d3e0c
Remove commented out function
ralph-msft Mar 22, 2024
af1c514
Minor tweaks
ralph-msft Mar 22, 2024
3190c30
Merge remote-tracking branch 'origin/main' into ralphe/telemetry
ralph-msft Mar 27, 2024
c7e82e3
Reduce delta
ralph-msft Mar 27, 2024
f8bdaf1
Add more documentation, minor code tweaks
ralph-msft Mar 27, 2024
e4c1c1c
Switch from Newtonsoft.Json to System.Text.Json
ralph-msft Mar 28, 2024
ce4f9b7
Tested init code paths. Fixed bugs.
ralph-msft Mar 30, 2024
2c0811a
Merge remote-tracking branch 'origin/main' into ralphe/refactor_azcli…
ralph-msft Apr 1, 2024
420a5d6
Merge remote-tracking branch 'origin/main' into ralphe/refactor_azcli…
ralph-msft Apr 3, 2024
26250eb
Fix test failuies
ralph-msft Apr 4, 2024
6b45609
Make the test proxy URL configurable via environment or build variable
ralph-msft Apr 5, 2024
db83201
Merge remote-tracking branch 'origin/main' into ralphe/refactor_azcli…
ralph-msft Apr 5, 2024
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
29 changes: 29 additions & 0 deletions ai-cli.sln
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,10 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution
NuGet.config = NuGet.config
EndProjectSection
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ClientsCLI", "src\clients.cli\ClientsCLI.csproj", "{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}"
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "UnitTests", "tests\UnitTests\UnitTests.csproj", "{BA7F8DB9-2789-4410-99B5-AC38F85697FE}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Expand Down Expand Up @@ -176,6 +180,30 @@ Global
{306A3CD6-91C2-450B-9995-79701CE63FE2}.Release|x64.Build.0 = Release|Any CPU
{306A3CD6-91C2-450B-9995-79701CE63FE2}.Release|x86.ActiveCfg = Release|Any CPU
{306A3CD6-91C2-450B-9995-79701CE63FE2}.Release|x86.Build.0 = Release|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Debug|Any CPU.Build.0 = Debug|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Debug|x64.ActiveCfg = Debug|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Debug|x64.Build.0 = Debug|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Debug|x86.ActiveCfg = Debug|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Debug|x86.Build.0 = Debug|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Release|Any CPU.ActiveCfg = Release|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Release|Any CPU.Build.0 = Release|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Release|x64.ActiveCfg = Release|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Release|x64.Build.0 = Release|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Release|x86.ActiveCfg = Release|Any CPU
{A136A55F-C27B-4FC9-82ED-84A3790BFC3C}.Release|x86.Build.0 = Release|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Debug|Any CPU.Build.0 = Debug|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Debug|x64.ActiveCfg = Debug|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Debug|x64.Build.0 = Debug|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Debug|x86.ActiveCfg = Debug|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Debug|x86.Build.0 = Debug|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Release|Any CPU.ActiveCfg = Release|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Release|Any CPU.Build.0 = Release|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Release|x64.ActiveCfg = Release|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Release|x64.Build.0 = Release|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Release|x86.ActiveCfg = Release|Any CPU
{BA7F8DB9-2789-4410-99B5-AC38F85697FE}.Release|x86.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
Expand All @@ -189,6 +217,7 @@ Global
{39876475-2D98-40CF-8B08-CD423A5EB4E8} = {C8AFF891-D6AA-4B8F-BC21-10404DF4B355}
{9499C018-FA08-4133-93B3-FC0F3863A6CC} = {C8AFF891-D6AA-4B8F-BC21-10404DF4B355}
{CED7C805-0435-4BF7-A42F-9F3BBF14A18F} = {644B75F1-C768-4DB3-BAF2-C69A1F36DD28}
{BA7F8DB9-2789-4410-99B5-AC38F85697FE} = {C8AFF891-D6AA-4B8F-BC21-10404DF4B355}
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {002655B1-E1E1-4F2A-8D53-C9CD55136AE2}
Expand Down
22 changes: 20 additions & 2 deletions src/ai/Program_AI.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,11 @@
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Azure.AI.CLI.Clients.AzPython;
using Azure.AI.CLI.Common.Clients;
using Azure.AI.Details.Common.CLI.Telemetry;
using Azure.AI.Details.Common.CLI.Telemetry.Events;


namespace Azure.AI.Details.Common.CLI
{
public class AiProgram
Expand Down Expand Up @@ -78,6 +79,17 @@ public AiProgramData()
_telemetry = new Lazy<ITelemetry>(
() => TelemetryHelpers.InstantiateFromConfig(this),
System.Threading.LazyThreadSafetyMode.ExecutionAndPublication);

var environmentVariables = LegacyAzCli.GetUserAgentEnv();

LoginManager = new AzConsoleLoginManager(
() => Values?.GetOrDefault("init.service.interactive", true) ?? true,
environmentVariables);

var azCliClient = new AzCliClient(environmentVariables);
SubscriptionsClient = azCliClient;
CognitiveServicesClient = azCliClient;
SearchClient = azCliClient;
}

#region name data
Expand Down Expand Up @@ -182,7 +194,7 @@ public bool DispatchParseCommand(INamedValueTokens tokens, ICommandValues values
var command = values.GetCommand(null) ?? tokens.PeekNextToken();
var root = command.Split('.').FirstOrDefault();

return root switch
return root switch
{
"help" => HelpCommandParser.ParseCommand(tokens, values),
"init" => InitCommandParser.ParseCommand(tokens, values),
Expand Down Expand Up @@ -262,5 +274,11 @@ public bool DisplayKnownErrors(ICommandValues values, Exception ex)

public IEventLoggerHelpers EventLoggerHelpers => new AiEventLoggerHelpers();
public ITelemetry Telemetry => _telemetry.Value;

public ILoginManager LoginManager { get; }
public ISubscriptionsClient SubscriptionsClient { get; }
public ICognitiveServicesClient CognitiveServicesClient { get; }
public ISearchClient SearchClient { get; }
public ICommandValues Values { get; } = new CommandValues();
}
}
1 change: 1 addition & 0 deletions src/ai/ai-cli.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,7 @@
</ItemGroup>

<ItemGroup>
<ProjectReference Include="..\clients.cli\ClientsCLI.csproj" />
<ProjectReference Include="..\common\common.csproj" />
<ProjectReference Include="..\extensions\helper_functions_extension\helper_functions_extension.csproj" />
<ProjectReference Include="..\extensions\speech_extension\speech-extension.csproj" />
Expand Down
39 changes: 20 additions & 19 deletions src/ai/commands/init_command.cs
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ private async Task DoInitRootVerifyConfigFileAsync(bool interactive, string file
if (openai != null && search != null)
{
bool? useSaved = await DoInitRootConfirmVerifiedProjectResources(
interactive, subscription, projectName, hubName, openai.Value, search.Value);
interactive, subscription, projectName, hubName, openai, search);

detail = useSaved.HasValue
? useSaved == true ? "saved_config" : "something_else"
Expand Down Expand Up @@ -186,18 +186,19 @@ private async Task DoInitRootVerifyConfigFileAsync(bool interactive, string file

ConsoleHelpers.WriteLineWithHighlight("\n `ATTACHED SERVICES AND RESOURCES`\n");

var message = " Validating...";
Console.Write(message);
string indent = " ";
using var cw = new ConsoleTempWriter($"{indent}Validating...");

var (hubName, openai, search) = await AiSdkConsoleGui.VerifyResourceConnections(_values, validated?.Id, groupName, projectName);
if (openai != null && search != null)
{
Console.Write($"\r{new string(' ', message.Length)}\r");
return (hubName, openai, search);
}
else
{
ConsoleHelpers.WriteLineWithHighlight($"\r{message} `#e_;WARNING: Configuration could not be validated!`");
cw.Clear();
Console.Write(indent);
ConsoleHelpers.WriteLineWithHighlight($"`#e_;WARNING: Configuration could not be validated!`");
Console.WriteLine();
return (null, null, null);
}
Expand Down Expand Up @@ -292,20 +293,20 @@ private async ValueTask DoInitRootMenuPick()
int selected = -1;

var outcome = Program.Telemetry.Wrap(() =>
{
selected = ListBoxPicker.PickIndexOf(choices.Select(e => e.DisplayName).ToArray());
if (selected < 0)
{
Console.WriteLine($"\r{label}: CANCELED (no selection)");
return Outcome.Canceled;
}
selected = ListBoxPicker.PickIndexOf(choices.Select(e => e.DisplayName).ToArray());
if (selected < 0)
{
Console.WriteLine($"\r{label}: CANCELED (no selection)");
return Outcome.Canceled;
}

Console.Write($"\r{label.Trim()}: {choices.ElementAtOrDefault(selected)?.DisplayName}\n");
_values.Reset("telemetry.init.run_type", choices.ElementAtOrDefault(selected)?.Metadata);
Console.Write($"\r{label.Trim()}: {choices.ElementAtOrDefault(selected)?.DisplayName}\n");
_values.Reset("telemetry.init.run_type", choices.ElementAtOrDefault(selected)?.Metadata);

return Outcome.Success;
},
(outcome, ex, timeTaken) => choices.ElementAtOrDefault(selected)?.Metadata == "standalone"
return Outcome.Success;
},
(outcome, ex, timeTaken) => choices.ElementAtOrDefault(selected)?.Metadata == "standalone"
? null
: new InitTelemetryEvent(InitStage.Choice)
{
Expand Down Expand Up @@ -337,11 +338,11 @@ private async Task DoInitStandaloneResources(bool interactive)

var choices = new[]
{
new { DisplayName = "Azure AI Services (v2)", Value = "init-root-cognitiveservices-ai-services-kind-create-or-select", Metadata = "aiservices" },
new { DisplayName = "Azure AI Services (v2)", Value = "init-root-cognitiveservices-ai-services-kind-create-or-select", Metadata = "aiservices" },
new { DisplayName = "Azure AI Services (v1)", Value = "init-root-cognitiveservices-cognitiveservices-kind-create-or-select", Metadata ="cognitiveservices" },
new { DisplayName = "Azure OpenAI", Value = "init-root-openai-create-or-select", Metadata = "openai" },
new { DisplayName = "Azure Search", Value = "init-root-search-create-or-select", Metadata = "search" },
new { DisplayName = "Azure Speech", Value = "init-root-speech-create-or-select", Metadata = "speech" }
new { DisplayName = "Azure Speech", Value = "init-root-speech-create-or-select", Metadata = "speech" }
};

int picked = -1;
Expand Down Expand Up @@ -535,7 +536,7 @@ private async Task DoInitOpenAi(bool interactive, bool skipChat = false, bool al
var regionFilter = _values.GetOrEmpty("init.service.resource.region.name");
var groupFilter = _values.GetOrEmpty("init.service.resource.group.name");
var resourceFilter = _values.GetOrEmpty("init.service.cognitiveservices.resource.name");
var kind = _values.GetOrDefault("init.service.cognitiveservices.resource.kind", "OpenAI;AIServices");
var kind = _values.GetOrDefault("init.service.cognitiveservices.resource.kind", "AIServices;OpenAI");
var sku = _values.GetOrDefault("init.service.cognitiveservices.resource.sku", Program.CognitiveServiceResourceSku);
var yes = _values.GetOrDefault("init.service.cognitiveservices.terms.agree", false);

Expand Down
Loading
Loading