使用单个数据库连接运行测试套件

时间:2014-07-09 13:35:01

标签: selenium selenium-webdriver

我被问到一个我不知道答案的问题。 他问我。

  • 我有5个测试套件(每个测试套件都有许多用Selenium编写的测试用例)
  • 我只想打开一个数据库并运行所有测试套件。

我该怎么做?

请帮忙, 谢谢, JB。

1 个答案:

答案 0 :(得分:0)

singe31是正确的。我之前做过这件事就完成了这件事。

C#

    public class DataAccessObject
    {
        private static DataAccessObject _dataObject = null;
        private static readonly object _lock = new object();
        public static DataAccessObject dataObj {
            get {
                lock (_lock) {
                    if (_dataObject == null) {
                        _dataObject = new DataAccessObject();
                    }
                    return _dataObject;
                }
            }
        }

        private DataAccessObject()
        {
            //populate your _dataObject in here
        }
    }

然后在您的代码中,您可以使DataAccessObject的实例等于公共财产private DataAccessObject _dataObject = DataAccessObject.dataObj

这将命中属性并拉入内存中的只读值并将其分配给本地变量。如果它已经存在,那么它只会拉出内存中的内容,否则它将实例化一个新实例并返回它,下一个测试将获得内存中的一个。

如果你想同时使用2,则_lock用于线程目的。它将锁定对一个的访问并导致另一个等到它完成后才开始。这样你只需要实例化一次,而不是冒着腐败的风险做一次并在之后覆盖它。