JustMock将匿名类型解释为元组。下面的示例演示了这个问题:
公共接口IAnsweringService{(int代码,字符串desc) GetAnswer (字符串问题);} (TestMethod]公共无效AnswerToTheUniverseQuestionTest(){varapiMock = Mock.Create();varexpectedAnswer =新{code =42, desc =《生命终极问题的答案》};Mock.Arrange(() => apiMock.GetAnswer(Arg.AnyString)).Returns(expectedAnswer);varactualAnswer = apiMock。GetAnswer (“宇宙问题的答案是什么?”);Assert.AreEqual (expectedAnswer。代码,actualAnswer.code);Assert.AreEqual (expectedAnswer.desc actualAnswer.desc);}
Telerik.JustMock.Core.MockException:链接返回值类型'<>f__AnonymousType1 ' 2[System. int32,System. int32]'与安排方法的返回类型'System.ValueTuple '不兼容' 2[System.Int32,System.String]'
以下代码片段在调试时导致测试执行中的挂起:
模拟。SetupStatic (typeof(时间间隔),行为。CallOriginal StaticConstructor.NonMocked);Mock.Arrange(() => TimeSpan。FromSeconds (15) .Returns (TimeSpan.MinValue);
这个问题可以通过通过JustMock扩展菜单禁用DebugWindow来临时解决。
你好
我生成了一个语法树,我将使用Formatter.Format()从软件包Microsoft.CodeAnalysis.CSharp.Workspaces 4.4.0和。net 6中格式化它。在使用格式化器的地方存在一个测试,但是当启用JustMock分析器时,会抛出InvalidProgramException。当分析器被禁用时,一切工作正常。它在Windows和Linux上都失败。
信息:
系统。InvalidProgramException:公共语言运行库检测到无效程序。
堆栈跟踪:
ContextIntervalTree”2。男星(TIntrospector&内省)
FormattingContext。函数(AbstractFormatEngine引擎,TokenStream)
AbstractFormatEngine。CreateFormattingContext(TokenStream TokenStream, CancellationToken CancellationToken)
AbstractFormatEngine。格式(CancellationToken CancellationToken)
CSharpSyntaxFormatting。Format(SyntaxNode节点,SyntaxFormattingOptions选项,IEnumerable ' 1 formattingRules, SyntaxToken startToken, SyntaxToken endToken, CancellationToken CancellationToken)
AbstractSyntaxFormatting。GetFormattingResult(SyntaxNode节点,IEnumerable ' 1跨度,SyntaxFormattingOptions选项,IEnumerable ' 1规则,CancellationToken CancellationToken)
格式化程序。GetFormattingResult(SyntaxNode节点,IEnumerable ' 1跨度,Workspace工作空间,OptionSet选项,IEnumerable ' 1规则,CancellationToken)
格式化程序。格式(SyntaxNode节点,IEnumerable ' 1跨度,Workspace工作空间,OptionSet选项,IEnumerable ' 1规则,CancellationToken)
格式化程序。Format(SyntaxNode node, Workspace Workspace, OptionSet options, CancellationToken CancellationToken)
UnitTest1.Test1()第23行
你可以通过编写一个单元测试(我使用xUnit)来重现这一点:
[事实]公共无效Test1(){varclassText =@“使用系统;名称空间TestNameSpace。订单{公共类订单{公共Guid Id {get;设置;}}}”;varsyntaxTree = CSharpSyntaxTree.ParseText(classText);var工作区=新AdhocWorkspace ();varformattedClassText = Formatter.Format(syntaxTree.GetRoot(), workspace).ToFullString();var预期=@“使用系统;名称空间TestNameSpace。订单{公共类订单{公共Guid Id {get;设置;}}}”;断言。平等(预期,formattedClassText);}}
见附件。我们不使用免费版。
dotnet——信息
. net SDK:
版本:7.0.200
提交:534117727 b
运行环境:
操作系统名称:Windows
操作系统版本:10.0.19045
操作系统平台:Windows
消除:win10-x64
基本路径:C:\Program Files\dotnet\sdk\7.0.200\
主持人:
版本:7.0.3
架构:x64
提交:0 a2bda10e8
.NET sdk安装:
6.0.406 [C:\Program Files\dotnet\sdk]
7.0.200 [C:\Program Files\dotnet\sdk]
.NET运行时安装:
Microsoft.AspNetCore.App 6.0.14 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
Microsoft.AspNetCore.App 7.0.3 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
Microsoft.NETCore.App 6.0.14 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
Microsoft.NETCore.App 7.0.3 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
Microsoft.WindowsDesktop.App 6.0.14 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
Microsoft.WindowsDesktop.App 7.0.3 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]
发现的其他架构:
x86 [C:\Program Files (x86)\dotnet]
已注册于[HKLM\SOFTWARE\dotnet\Setup\InstalledVersions\x86\InstallLocation]
环境变量:
没有设置
全球。json文件:
没有找到
了解更多:
https://aka.ms/dotnet/info
下载。net:
https://aka.ms/dotnet/download
考虑以下简单的测试场景:
公共摘要类TestBase{公共静态TestContext TestContext {得到;集;}} [TestClass]公共类UnitTest1:TestBase{(ClassInitialize]公共静态无效ClassInitlialize(和TestContext ctx){TestContext = ctx;} (TestMethod]公共无效TestMethod1(){}} [TestClass]公共类UnitTest2:TestBase{(ClassInitialize]公共静态无效ClassInitlialize(和TestContext ctx){TestContext = ctx;} (TestMethod]公共无效TestMethod1(){}}
尝试在启用JustMock分析器的情况下运行上述测试,会出现System.InvalidProgramException异常。这个问题不能在MSTest中重现。TestFramework和MSTest。外种皮dapter packages prior to 3.0.x.
下面的例子演示了这个问题:
[理论] [MemberData (nameof (GetMemberDataContext))]公共无效ValidParameters_Success(intparam1,intparam2){/ /安排模拟。SetupStatic (typeof(MyClass)的行为。严格,StaticConstructor.Mocked);Mock.Arrange(() => MyClass.method1()). return (真正的);/ /行为IService服务=新服务();保龄球Result = service.method2();/ /维护Assert.True(结果);Mock.Assert(() => MyClass.method1(), Occurs.Once());// <——此处测试失败,因为它报告方法调用发生了两次}
如果按照以下方式修改代码,则无法观察到问题,这表明行为不一致:
[理论] [MemberData (nameof (GetMemberDataContext))]公共无效ValidParameters_Success(intparam1,intparam2){/ /安排模拟。SetupStatic (typeof(MyClass)的行为。严格,StaticConstructor.Mocked);Mock.Arrange(() => MyClass.method1()). return (真正的) .OccursOnce ();/ /行为IService服务=新服务();保龄球Result = service.method2();/ /维护Assert.True(结果);Mock.Assert < MyClass > ();}
如果您使用c# using声明并启用了JustMock高级(提升)模式,则运行时将抛出InvalidProgramException。
下面是演示该问题的示例代码:
公共类TestClass:IDisposable{公共无效处理(){}}
[TestClass]公共类夹具{公共接口它{} [TestMethod]公共异步任务测试(){ITest mock = mock . create ();使用TestClass test =新();}}
UI应用程序的线程模型与测试主机不同,这可能会导致以下问题:系统。InvalidOperationException: "调用线程必须是STA,因为许多UI组件需要这个".这个请求是关于用一些可以用来轻松解决这个问题的帮助器扩展JustMock。
考虑样例类
使用Azure.Messaging.ServiceBus;公共类类别2{私人静态ServiceBusSender messageToTopicSender;私人静态字符串topicName;公共静态无效SetRequestTopicClient(字符串serviceBusConnectionString,字符串topName){topicName = topName;ServiceBusClient =新ServiceBusClient (serviceBusConnectionString);messageToTopicSender = serviceBusClient.CreateSender(topicName);}}
下面的测试
[TestClass]公共类Class1Test{(TestInitialize]公共无效设置(){Mock.Arrange(() => Class2。SetRequestTopicClient (”“,”“) .DoNothing ();} (TestMethod]公共无效外种皮(){Class2。SetRequestTopicClient (”“,”“);}} [TestClass]公共类Class2Test{静态ServiceBusClient = Mock.Create();messageToTopicSender = Mock.Create();[TestInitialize]公共无效设置(){Mock.Arrange(() =>新ServiceBusClient (“若干”) .Returns (serviceBusClient);Mock.Arrange(() => serviceBusClient。CreateSender (“myTopic”) .Returns (messageToTopicSender);} (TestMethod]公共无效的(){Class2。SetRequestTopicClient (“若干”,“myTopic”);}}
按照TestA -> TestB的顺序执行测试会导致TestB失败,但更改顺序或单独运行测试会成功。测试的结果不应该依赖于执行顺序。
新的公共API应该允许开发人员访问特定安排的调用。类似于以下内容:
IEnumerable< iinvociton > invocationsfor = foo.GetInvocationsFor((x) => x. calcdata (2,2));
实现一个新的公共API,允许开发人员遍历模拟安排的所有调用。类似于以下内容:
IEnumerable< iinvocation > invocations = Mock.Invocations;