首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >从Java/Junit4迁移到Scala/ScalaTest

从Java/Junit4迁移到Scala/ScalaTest
EN

Stack Overflow用户
提问于 2011-04-30 14:22:52
回答 1查看 816关注 0票数 0

我有一些关于ScalaTest的问题:

我如何确保ScalaTest的测试执行顺序,我可以继续使用Junit4的@Suite.SuiteClasses注解吗?或者有没有其他方法根本不使用Junit?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@RunWith(Suite.class)
@Suite.SuiteClasses({
    FirstTest.class, SecondTest.class
  })
public class MyTestSuite {
  @BeforeClass
  public void setup() {
    public MyDB db = new DB("config");
  }
}

我能不能把上面的代码翻译成Scala,然后就可以使用了?

另一个问题是:

如何使"db“字段对Suite-Classes可用?在Java中,这个字段是静态的,所以我可以从所有Suite类中引用它。

也许可以定义一个包含引用的伴生对象?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-05-01 13:57:58

在ScalaTest中,一个套件可以包含零到多个测试,也可以包含零到多个嵌套套件。套件的嵌套套件由其nestedSuites方法提供,要运行的测试的名称由其testNames方法提供。一般的答案是,对于任何内置的ScalaTest风格特征,嵌套套件和测试执行的顺序由它们在nestedSuites和testNames的返回值中出现的顺序决定。因此,如果你没有得到你想要的顺序,那么你可以覆盖这两个方法中的一个或两个。

然而,对于测试顺序,简单地使用其中一个测试是函数的特征可能要容易得多,因为这些特征按照它们在源代码中出现的顺序运行测试。(相比之下,套件按测试名称的字母顺序运行测试。)因此,我建议您使用FunSuite作为初学者。例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import org.scalatest.FunSuite

class MySuite extends FunSuite {
  test("this one will run first because it appears first") {
    // ...
  }
  test("this one will run second because it appears second") {
    // ...
  }
  test("this one will run third, and so on") {
    // ...
   }
 }

至于让套件按顺序运行,这是很少见的,因为人们喜欢在编写新套件时使用发现来发现它们。但要做到这一点,方法是覆盖nestedSuites。在1.5版本中,Suites类提供了一种方便的方式来实现这一点:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import org.scalatest.Suites

class MySuites extends Suites(
  new MyFirstSuite,
  new MySecondSuite,
  new MyThirdSuite,
  new MyFourthSuite
)

然后运行MySuites,它将按照您声明的顺序运行其嵌套套件。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5842348

复制
相关文章
oracle创建表空间脚本
/分为四步 / /第1步:创建临时表空间 / create temporary tablespace airforce34 tempfile 'D:\date\airforce34.dbf' size 100m autoextend on ; --删除临时表空间: DROP TABLESPACE airforce34 INCLUDING CONTENTS AND DATAFILES; /*第2步:创建数据表空间 */ create table
用户8983410
2021/11/02
1.8K0
Oracle 数据库直接执行本地sql文件、sql脚本实例演示
@ + sql 文件路径即可执行 sql 文件里的 sql 语句。 实例演示: 我要执行的 sql 文件路径是 C:\Users\Administrator\Desktop\delete.sql , 登录以后直接执行 @C:\Users\Administrator\Desktop\delete.sql 就好了。
小蓝枣
2020/09/24
2.5K0
Oracle 性能相关常用脚本(SQL)
在缺乏的可视化工具来监控数据库性能的情形下,常用的脚本就派上用场了,下面提供几个关于Oracle性能相关的脚本供大家参考。以下脚本均在Oracle 10g测试通过,Oracle 11g可能要做相应调整。
Leshami
2018/08/13
9200
oracle 全文检索创建脚本示例
grant execute on ctx_ddl to username;--使用其他帐号对username授权 exec ctx_ddl.create_preference('my_lexer','chinese_lexer');--创建chinese_lexer词法器(中文词法分析器) exec ctx_ddl.create_preference('my_filter','CHARSET_FILTER');--创建字符过滤器 exec ctx_ddl.set_attribute('my_filter','charset','ZHS16GBK');--设置过滤器字符编码 create index idx_tablename_colname on tablename(colname) indextype is ctxsys.context parameters('lexer my_lexer');--在tablename上创建索引
程序员一一涤生
2019/09/10
7190
SQL-spj库创建脚本
spj库创建脚本 CREATE TABLE j ( jno char(3) NOT NULL, -- 工程项目号 jname varchar(10) DEFAULT NULL, city varchar(10) DEFAULT NULL, PRIMARY KEY (jno) ); CREATE TABLE p ( pno char(3) NOT NULL, -- 零件号 pname varchar(10) DEFAULT NULL, color char(2) DEFAULT
唔仄lo咚锵
2020/09/15
3200
Oracle Sqlplus 运行环境 login.sql 设置[通俗易懂]
在运行Sqlplus时经常需要对运行环境进行设置,如果每次输入都要调整参数会比较麻烦,因此可以利用Oracle提供的glogin.sql、login.sql这两个文件对Sqlplus进行环境初始化。
全栈程序员站长
2022/09/13
1.6K0
Oracle Sqlplus 运行环境 login.sql 设置[通俗易懂]
SQL%NOTFOUND_oracle导出sql文件
SQL%NOTFOUND 是一个布尔值。与最近的sql语句(update,insert,delete,select)发生交互,当最近的一条sql语句没有涉及任何行的时候,则返回true。否则返回false。这样的语句在实际应用中,是非常有用的。例如要update一行数据时,如果没有找到,就可以作相应操作。如:
全栈程序员站长
2022/09/20
8060
Oracle 创建表空间和用户脚本
===============================================================
FHAdmin
2022/03/11
1.1K0
工具| 将你如何打包py文件脱机运行
上次给大家透露了本期文章是爬取抖音小视频,因为我们没有介绍过如何爬取app,因此依旧是爬取网站。抖音有一个国际版,其网址是https://www.tiktok.com/,但是在国内访问不了,你需要翻墙。很不幸这篇文章写到一半的时候,我的梯子挂掉了,所以这篇文章就先搁浅了。等后面有空就出几篇基于app的爬虫文章,今天我们的主题是如何将py文件打包成exe格式,以便于在Windows系统上脱机运行。好了话不多说,走你。
啃饼思录
2019/04/25
2.3K0
工具| 将你如何打包py文件脱机运行
Oracle创建数据库语句_oracle创建表的sql语句
create tablespace SOA logging datafile ‘D:\app\oradata\ORCL\SOA.dbf’ size 32m autoextend on next 32m maxsize 2048m extent management local;
全栈程序员站长
2022/11/08
3.1K0
SQL Server基础SQL脚本之创建架构、排序
代码420行左右 本系列,几乎都是代码,记得当时写的时候用的是微软的官方实例数据库AdventureWorks_Data.mdf、AdventureWorks_Log.ldf来运行的。 下载链接:链接: https://pan.baidu.com/s/1pMdLz6N 密码: xvhu 或者回复“AdventureWorks”来获取链接。 ---- --一,创建数据库 。 create database XXXDB--创建数据库 use XXXDB--使用数据库 create table Depart
赵腰静
2018/03/09
1.2K0
oracle删除索引_创建普通索引sql
a) 唯一索引, 作用是数据约束,保证数据唯一,还有就是数据索引,提高查询效率
全栈程序员站长
2022/10/03
8300
oracle创建表空间的SQL语句
oracle创建表空间语句: create tablespace shopping –创建一个叫shopping的表空间 datafile ‘shopping.dbf’ –物理文件名 size 50m –大小 autoextend on –自动增长 next 50m maxsize 20480m –每次扩展50m,最大为20480m extent management local;
全栈程序员站长
2022/09/18
4.2K0
oracle 创建索引的sql语句_oracle数据库创建索引语句
CREATE INDEX POLICYIMPART_INDEX ON ROOTE.W_POLICYIMPART( POLICYID ASC, IMPARTCODE ASC, CUSTOMERTYPE ASC
全栈程序员站长
2022/10/04
2K0
oracle创建索引的sql语句_mysql创建组合索引
创建索引一般分为在线索引和非在线索引,在线与非在线的区别:非在线锁表,优先创建索引,此时DML都被阻塞,所以快;相反,在线锁的是行而非表,通过临时表进行索引的创建,所以不会影响DML操作,但副作用就是慢。 如果在生产环境操作,不停服务的话,势必导致创建索引期间仍有DML操作进来。另外如果是大表,那么采用非在线而导致锁表所带来的影响可能会很大。一句话,生产环境不停服的脚本操作,建议使用online。 1、创建索引。
全栈程序员站长
2022/10/03
3.8K0
创建ORACLE大文件表空间
ORA-01144: File size (26214400 blocks) exceeds maximum of 4194303 blocks
全栈程序员站长
2022/09/18
2.4K0
创建ORACLE大文件表空间
oracle创建表设置主键自增_sql如何设置自增
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/03
3.6K0
oracle脚本删除多实例aud文件
for i in $(ps -ef|grep ora_smon|grep -v grep|awk '{print $NF}'|cut -c 10-)
彻底
2023/07/07
5490
oracle创建表的sql语句「建议收藏」
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/03
1.3K0
点击加载更多

相似问题

Oracle SQL脚本-为什么假脱机创建两次文件

14

oracle sql plus假脱机

70

Oracle SQL Developer假脱机输出?

710

Oracle SQL Developer -假脱机错误

24

Oracle SQL并行假脱机自动

22
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文