Skip to content

Commit

Permalink
Add IotCentralTestRunner to replace IotCentralController (#18130)
Browse files Browse the repository at this point in the history
  • Loading branch information
v-yuzhichen authored May 13, 2022
1 parent 1da2111 commit ee78012
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 143 deletions.
134 changes: 0 additions & 134 deletions src/IotCentral/IotCentral.Test/ScenarioTests/IotCentralController.cs

This file was deleted.

Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
// ----------------------------------------------------------------------------------
//
// Copyright Microsoft Corporation
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// http://www.apache.org/licenses/LICENSE-2.0
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// ----------------------------------------------------------------------------------

using System.Collections.Generic;
using Microsoft.Azure.Commands.TestFx;
using Xunit.Abstractions;

namespace Microsoft.Azure.Commands.IotCentral.Test.ScenarioTests
{
public class IotCentralTestRunner
{
protected readonly ITestRunner TestRunner;

protected IotCentralTestRunner(ITestOutputHelper output)
{
TestRunner = TestManager.CreateInstance(output)
.WithNewPsScriptFilename($"{GetType().Name}.ps1")
.WithProjectSubfolderForTests("ScenarioTests")
.WithCommonPsScripts(new[]
{
@"Common.ps1",
@"../AzureRM.Resources.ps1"
})
.WithNewRmModules(helper => new[]
{
helper.RMProfileModule,
helper.GetRMModulePath(@"Az.IotCentral.psd1")
})
.WithNewRecordMatcherArguments(
userAgentsToIgnore: new Dictionary<string, string>
{
{"Microsoft.Azure.Management.Resources.ResourceManagementClient", "2021_04_01"},
{"Microsoft.Azure.Management.ResourceManager.ResourceManagementClient", "2017-05-10"},
{"Microsoft.Azure.Management.Internal.Resources.ResourceManagementClient", "2016-09-01"}
},
resourceProviders: new Dictionary<string, string>
{
{"Microsoft.Resources", null},
{"Microsoft.Features", null},
{"Microsoft.Authorization", null}
}
)
.Build();
}
}
}
12 changes: 3 additions & 9 deletions src/IotCentral/IotCentral.Test/ScenarioTests/IotCentralTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -12,29 +12,23 @@
// limitations under the License.
// ----------------------------------------------------------------------------------

using Microsoft.Azure.ServiceManagement.Common.Models;
using Microsoft.WindowsAzure.Commands.ScenarioTest;
using Microsoft.WindowsAzure.Commands.Test.Utilities.Common;
using Xunit;
using Xunit.Abstractions;

namespace Microsoft.Azure.Commands.IotCentral.Test.ScenarioTests
{
public class IotCentralTests : RMTestBase
public class IotCentralTests : IotCentralTestRunner
{
public XunitTracingInterceptor _logger;

public IotCentralTests(ITestOutputHelper output)
public IotCentralTests(ITestOutputHelper output) : base(output)
{
_logger = new XunitTracingInterceptor(output);
XunitTracingInterceptor.AddToContext(_logger);
}

[Fact]
[Trait(Category.AcceptanceType, Category.CheckIn)]
public void TestIotCentralAppLifecycleManagement()
{
IotCentralController.NewInstance.RunPsTest(_logger, "Test-IotCentralAppLifecycleManagement");
TestRunner.RunTestScript("Test-IotCentralAppLifecycleManagement");
}
}
}

0 comments on commit ee78012

Please sign in to comment.