java - 如何限制(队列)针对给定数据库执行的线程数量(每个并发测试的单独数据)?

标签 java multithreading selenium selenium-webdriver automated-tests

我构建了一个同时执行测试套件的自动化框架。

目前,如果我的DB命令由多个线程(测试)同时执行,则数据不正确。

我尝试过使用静态、同步等,但没有成功,有什么想法吗?

示例代码:

public static synchronized String createAccount() throws IOException, SQLException {
    DbManager.createDatabaseConnection();
    DbManager.executeSqlUpdateStatement(Account_Creation_Scripts.createAccount_Sql_Command());
    account_pojo.setAccountEmail(locateMostRecentlyCreatedAccount());
    LoggerInstance.log("Account created: " + account_pojo.getUniEmail());
    DbManager.closeDatabaseConnection();
    return tutor_pojo.getAccountEmail();
}

如果我使用 x1 线程实例运行代码,每个测试都会从数据库等创建并提取正确的帐户。

请注意:

  • 没有异常发生。
  • 仅当同时运行多个线程时才会出现此问题,例如:
test1 = uses account: email1@email.com
test2 = uses account: email2@email.com
test3 = uses account: email3@email.com
test4 = uses account: email3@email.com

正如您所看到的,test3 和 4 使用相同的电子邮件地址,即使 email1-4@email.com 在数据库中可见。

最佳答案

您需要考虑使测试具有事务性并选择正确的事务隔离。 在您的测试中发生的情况是,Thread4 创建帐户,然后 Thread3 创建帐户,之后两个线程都尝试选择最近创建的帐户并获取相同的值。

此外,您无法控制此处的输入。 您可能需要更改代码以接受 createAccountMethod 中的某些参数,在这种情况下,您的每个测试都可以使用单独的硬编码电子邮件。

关于java - 如何限制(队列)针对给定数据库执行的线程数量(每个并发测试的单独数据)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60061551/

相关文章:

java - 在 sonatype 上发布 - 无公钥

java在第二类中找不到构造函数

c++ - 如何同步写入线程和读取线程之间的数据库访问?

python - xPath:将表达式与实际源代码匹配困难

java - cucumber JUnit : How to take screenshot when scenario step definitions are spread across classes?

java - Slick addState java.lang.Error

java - CompletableFuture#whenComplete 如果使用 thenApply 则不调用

python - 线程池执行器 : how to limit the queue maxsize?

java - 我应该使用 ConcurrentHashMap 还是 Hashmap 还是 SynchronizedMap?

javascript - cucumber Protractor - 错误 : function timed out after 50000 milliseconds