forked from microsoft/typespec
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Adopt versioning Cadl-Ranch specs (microsoft#5273)
Fixes microsoft#3965 Filed Azure/cadl-ranch#779 as versioning is implemented in tsp compiler. --------- Co-authored-by: Jorge Rangel <102122018+jorgerangel-msft@users.noreply.github.com>
- Loading branch information
1 parent
fc51b1f
commit 11d6f49
Showing
157 changed files
with
10,076 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
56 changes: 56 additions & 0 deletions
56
...generator/TestProjects/CadlRanch.Tests/Http/Versioning/Added/V1/VersioningAddedV1Tests.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
// Copyright (c) Microsoft Corporation. All rights reserved. | ||
// Licensed under the MIT License. | ||
|
||
using NUnit.Framework; | ||
using System; | ||
using System.Linq; | ||
using Versioning.Added.V1; | ||
using Versioning.Added.V1.Models; | ||
|
||
namespace TestProjects.CadlRanch.Tests.Http.Versioning.Added.V1 | ||
{ | ||
public class VersioningAddedV1Tests : CadlRanchTestBase | ||
{ | ||
[CadlRanchTest] | ||
public void TestAddedMembersV1Client() | ||
{ | ||
/* verify ModelV1. */ | ||
var properties = typeof(ModelV1).GetProperties(); | ||
Assert.IsNotNull(properties); | ||
Assert.AreEqual(2, properties.Length); | ||
/* verify property UnionProp added in V2 is not present.*/ | ||
Assert.IsNull(typeof(ModelV1).GetProperty("UnionProp")); | ||
|
||
/* verify EnumV1. */ | ||
Assert.True(typeof(EnumV1).IsEnum); | ||
var enumValues = typeof(EnumV1).GetEnumNames(); | ||
Assert.IsNotNull(enumValues); | ||
Assert.AreEqual(1, enumValues.Length); | ||
/* verify added enum value EnumMemberV2. */ | ||
Assert.IsFalse(enumValues.Contains("EnumMemberV2")); | ||
|
||
/* check existence of the added model ModelV2. */ | ||
Assert.IsNull(Type.GetType("Versioning.Added.V1.Models.ModelV2")); | ||
|
||
/* check existence of the added enum EnumV2. */ | ||
Assert.IsNull(Type.GetType("Versioning.Added.V1.Models.EnumV2")); | ||
|
||
/* check the added parameter. */ | ||
var methods = typeof(AddedClient).GetMethods().Where(m => m.Name == "V1" || m.Name == "V1Async"); | ||
Assert.IsNotNull(methods); | ||
Assert.AreEqual(4, methods.Count()); | ||
var methodsArray = methods.ToArray(); | ||
foreach (var method in methodsArray) | ||
{ | ||
Assert.IsFalse(method.GetParameters().Any(p => p.Name == "headerV2")); | ||
} | ||
|
||
/* check the existence of added method in V2. */ | ||
var addedMethods = typeof(AddedClient).GetMethods().Where(m => m.Name == "V2" || m.Name == "V2Async"); | ||
Assert.IsEmpty(addedMethods); | ||
|
||
/* check the existence of added interface in V2. */ | ||
Assert.IsNull(Type.GetType("Versioning.Added.V1.InterfaceV2")); | ||
} | ||
} | ||
} |
91 changes: 91 additions & 0 deletions
91
...generator/TestProjects/CadlRanch.Tests/Http/Versioning/Added/V2/VersioningAddedV2Tests.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
// Copyright (c) Microsoft Corporation. All rights reserved. | ||
// Licensed under the MIT License. | ||
|
||
using System.Threading.Tasks; | ||
using NUnit.Framework; | ||
using System; | ||
using System.Linq; | ||
using Versioning.Added.V2; | ||
using Versioning.Added.V2.Models; | ||
|
||
namespace TestProjects.CadlRanch.Tests.Http.Versioning.Added.V2 | ||
{ | ||
public class VersioningAddedV2Tests : CadlRanchTestBase | ||
{ | ||
[CadlRanchTest] | ||
public void TestAddedMembersV2Client() | ||
{ | ||
/* verify ModelV1. */ | ||
var properties = typeof(ModelV1).GetProperties(); | ||
Assert.IsNotNull(properties); | ||
Assert.AreEqual(3, properties.Length); | ||
/* verify added property UnionProp in V2.*/ | ||
Assert.IsNotNull(typeof(ModelV1).GetProperty("UnionProp")); | ||
|
||
/* verify EnumV1. */ | ||
Assert.True(typeof(EnumV1).IsEnum); | ||
var enumValues = typeof(EnumV1).GetEnumNames(); | ||
Assert.IsNotNull(enumValues); | ||
Assert.AreEqual(2, enumValues.Length); | ||
/* verify added enum value EnumMemberV2. */ | ||
Assert.IsTrue(enumValues.Contains("EnumMemberV2")); | ||
|
||
/* check existence of the added model ModelV2. */ | ||
Assert.IsNotNull(Type.GetType("Versioning.Added.V2.Models.ModelV2")); | ||
|
||
/* check existence of the added enum EnumV2. */ | ||
Assert.IsNotNull(Type.GetType("Versioning.Added.V2.Models.EnumV2")); | ||
|
||
/* check the added parameter. */ | ||
var methods = typeof(AddedClient).GetMethods().Where(m => m.Name == "V1" || m.Name == "V1Async"); | ||
Assert.IsNotNull(methods); | ||
Assert.AreEqual(4, methods.Count()); | ||
var methodsArray = methods.ToArray(); | ||
foreach (var method in methodsArray) | ||
{ | ||
Assert.IsTrue(method.GetParameters().Any(p => p.Name == "headerV2")); | ||
} | ||
|
||
/* check the existence of added method in V2. */ | ||
var addedMethods = typeof(AddedClient).GetMethods().Where(m => m.Name == "V2" || m.Name == "V2Async"); | ||
Assert.IsNotNull(addedMethods); | ||
Assert.AreEqual(4, addedMethods.Count()); | ||
|
||
/* check the existence of added interface in V2. */ | ||
Assert.IsNotNull(Type.GetType("Versioning.Added.V2.InterfaceV2")); | ||
} | ||
|
||
[CadlRanchTest] | ||
public Task Versioning_Added_v1() => Test(async (host) => | ||
{ | ||
ModelV1 modelV1 = new ModelV1("foo", EnumV1.EnumMemberV2, BinaryData.FromObjectAsJson(10)); | ||
var response = await new AddedClient(host).V1Async("bar", modelV1); | ||
Assert.AreEqual(200, response.GetRawResponse().Status); | ||
Assert.AreEqual("foo", response.Value.Prop); | ||
Assert.AreEqual(EnumV1.EnumMemberV2, response.Value.EnumProp); | ||
Assert.AreEqual(10, response.Value.UnionProp.ToObjectFromJson<int>()); | ||
}); | ||
|
||
[CadlRanchTest] | ||
public Task Versioning_Added_v2() => Test(async (host) => | ||
{ | ||
ModelV2 modelV2 = new ModelV2("foo", EnumV2.EnumMember, BinaryData.FromObjectAsJson("bar")); | ||
var response = await new AddedClient(host).V2Async(modelV2); | ||
Assert.AreEqual(200, response.GetRawResponse().Status); | ||
Assert.AreEqual("foo", response.Value.Prop); | ||
Assert.AreEqual(EnumV2.EnumMember, response.Value.EnumProp); | ||
Assert.AreEqual("bar", response.Value.UnionProp.ToObjectFromJson<string>()); | ||
}); | ||
|
||
[CadlRanchTest] | ||
public Task Versioning_Added_InterfaceV2() => Test(async (host) => | ||
{ | ||
ModelV2 modelV2 = new ModelV2("foo", EnumV2.EnumMember, BinaryData.FromObjectAsJson("bar")); | ||
var response = await new AddedClient(host).GetInterfaceV2Client().V2InInterfaceAsync(modelV2); | ||
Assert.AreEqual(200, response.GetRawResponse().Status); | ||
Assert.AreEqual("foo", response.Value.Prop); | ||
Assert.AreEqual(EnumV2.EnumMember, response.Value.EnumProp); | ||
Assert.AreEqual("bar", response.Value.UnionProp.ToObjectFromJson<string>()); | ||
}); | ||
} | ||
} |
Oops, something went wrong.