为 Xamarin Forms 应用程序编写单元测试的方法是什么(相对于 Xamarin Traditional,即 Xamarin.Android、Xamarin.IOS 或 Xamarin.UWP)?
谁能很好地解释 Xamarin.Forms 中的单元测试与 Xamarin Traditional 中的单元测试?
关于如何实现 Xamarin.Forms 测试的很好的解释文章,是否需要它们,或者我们是否应该为每个平台编写单元测试?
我已经阅读了很多文章,但还没有找到一篇从在 Visual Studio 中创建单元测试项目类型到编写和运行测试的文章。
他们大多从中间的某个地方开始讨论 DI 或 ServiceLocator(就像这个 http://arteksoftware.com/unit-testing-with-xamarin-forms-dependencyservice/ )。
或者,另一方面,他们将 Xamarin.Forms 与 Xamarin.Android(或 IOS)单元测试混合使用(例如:http://www.dsibinski.pl/2017/03/unit-testing-xamarin-application/)。
或者,他们将可移植和共享混合在一起,就像这个案例一样 http://www.alteridem.net/2015/12/21/testing-xamarin-projects-using-nunit-3/ .
到目前为止,我所了解的是我可以在 VS 中使用常规单元测试项目并使用 MSTest 或 NUnit。或者,我可以为每个平台编写特定于平台的单元测试。
所有这些都非常令人困惑,因为作者似乎到处都在混用这些术语。
如果我是该领域的新手,请提供详细的答案和支持示例,我们将不胜感激。
最佳答案
我有一段时间有同样的问题,我最终确定了一个策略,该策略由两部分组成,包括代码的单元测试和 UI 测试。
单元测试没有 UI 的代码。例如模型、服务等的测试。通常我有一个单元测试项目,单元测试是针对共享库编写的。
UI 测试特定于操作系统。我有一个 iOS 测试项目和一个 Android 测试项目。我考虑过拥有一个 UI 测试项目,这将是 Nirvana。我只是不相信它可以处理每个操作系统的所有 UI 细微差别。
在构建期间,我运行单元测试。如果它们通过,则运行 UI 测试。对于每个操作系统,我有两组测试,冒烟测试和深度测试。冒烟测试是在一小部分设备上完成的。在将测试时间浪费在糟糕的构建上之前,我可以快速判断构建的质量。然后在良好的构建上对相同的小设备子集执行深度测试。如果一切都通过,则会在更大的设备池上执行冒烟测试。如果崩溃报告出现在大型池中的设备上,则会执行深度测试。如果有问题的设备拥有足够大的用户群并且仍然存在问题,则会将其添加到深度池测试中。
我在非常非常长的职业生涯中学习了这份工作,包括在 Microsoft 工作 7 年,包括在几个团队中担任 PM,这些团队致力于 .NET Framework、.NET Framework SDK 和相关技术,例如 ASP.NET MVC、WebAPI 、Azure 等。我上面描述的构建过程大致基于 .NET Framework 和 .NET Framework SDK 的构建方式。 .NET 的构建需要一段时间。测试运行的时间甚至更长(想想物理日),因此将快速冒烟测试作为构建的一部分非常有用并且可以节省时间。有时构建会编译并产生安装,但会出现一些(相对而言)测试可能指向错误构建并为 QA 团队节省大量时间的问题。
下面的 Rookiejava 添加了一些很好的链接,用于学习如何编写测试。
我对设计测试的最佳建议是愚蠢、刻薄、严格和小鬼。通过愚蠢的测试,做一些不懂编程的人不会做的事情。最好的例子是在 I believe x-box 上发现的登录错误。某人的 child 做了一件非常古怪的事,你瞧,他父亲的账户就进了。我的意思是说做令人发疯的事情会让你发疯。双关语。例如点击您的产品。不是开玩笑,有一家保险柜大厂,把保险柜打在某个地方,可以不用密码打开!从字面上看要严格,不要做出假设。如果用例、用户故事或您用来了解代码应该如何工作的文档说疲劳,那么您的测试应该让代码仅在疲劳时通过,即使我们都知道它应该是疲劳。请提交针对用例/用户故事的错误;)我能提供的最大建议就是像小 Sprite 一样思考。不要只是测试快乐路径是否有效或数据验证规则是否有效。测试进行奇怪的输入和组合命令、按键等。我使用的最好的测试工具是用于 Windows Mobile 的 Microsoft 测试工具。是的,Windows。该工具会对应用程序的用户界面做完全随机的事情。随机按键将信息从下到上放置,甚至以随机顺序放置。很高兴看到有多少人不自觉地做出了我和其他人所做的假设。它甚至发现了一个错误,可以让某人完全访问我为政府机构工作的设备,不仅我们的团队错过了,而且其他外部安全测试人员也错过了。我们在设备进入开发之外的任何人之前悄悄地修补了它。
关于c# - Xamarin 表单单元测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44873933/
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser
我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r
我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel