При чтении файла свойств java значения продолжают обнуляться - PullRequest
0 голосов
/ 08 апреля 2020

Я пытаюсь прочитать значения из файла java свойств, чтобы я мог использовать их все в моих тестах. У меня есть BaseTest, который читает в свойствах. Когда я печатаю сразу после прочтения значений в BaseTest, значения отображаются правильно. Но когда я пытаюсь получить к ним доступ в test1, который расширяет BaseTest, значения равны нулю. У меня есть java класс, который принимает значения как шаблон, ничего не инициализировано. Значения заполняются классом TestValuesReader. Как сделать так, чтобы значения сохранялись во всем коде / не были нулевыми?

 public class test1 extends BaseTest {
        String var1 = TestValues.VAR1;

        @Test
        public void someFunction() throws InterruptedException {
            System.out.println(var1);
        }
}

public class BaseTest{

    public void readValues() throws IOException {
        Properties p = new Properties();
        InputStream is = new FileInputStream("TestValues.properties");
        p.load(is);
        TestValuesReader valuesReader = new TestValuesReader();
        valuesReader.readStrings(p);
    }

    @BeforeClass
    public void setUp() throws IOException {
        readValues();
        System.out.println(TestValues.VAR1); //this will give back the correct value, but when called
        //in someFunction() it is null
    }
}

public class TestValues{
    public static String VAR1; //not initialized, supposed to be ready from properties file
}

public class TestValuesReader {
    public void readStrings(Properties p) {
          TestValues.VAR1 = p.getProperty("VAR1");
    }
}




FAILED: checkForCandidate
java.lang.IllegalArgumentException: Keys to send should be a not null CharSequence
    at org.openqa.selenium.remote.RemoteWebElement.sendKeys(RemoteWebElement.java:97)
    at com.iai.test.pages.SpatialQuery.setAimPointInput(SpatialQuery.java:50)
    at com.iai.test.tests.cgm.CG_AX_001.checkForCandidate(CG_AX_001.java:21)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:134)
    at org.testng.internal.TestInvoker.invokeMethod(TestInvoker.java:597)
    at org.testng.internal.TestInvoker.invokeTestMethod(TestInvoker.java:173)
    at org.testng.internal.MethodRunner.runInSequence(MethodRunner.java:46)
    at org.testng.internal.TestInvoker$MethodInvocationAgent.invoke(TestInvoker.java:816)
    at org.testng.internal.TestInvoker.invokeTestMethods(TestInvoker.java:146)
    at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:146)
    at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:128)
    at java.util.ArrayList.forEach(ArrayList.java:1257)
    at org.testng.TestRunner.privateRun(TestRunner.java:766)
    at org.testng.TestRunner.run(TestRunner.java:587)
    at org.testng.SuiteRunner.runTest(SuiteRunner.java:384)
    at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:378)
    at org.testng.SuiteRunner.privateRun(SuiteRunner.java:337)
    at org.testng.SuiteRunner.run(SuiteRunner.java:286)
    at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:53)
    at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:96)
    at org.testng.TestNG.runSuitesSequentially(TestNG.java:1187)
    at org.testng.TestNG.runSuitesLocally(TestNG.java:1109)
    at org.testng.TestNG.runSuites(TestNG.java:1039)
    at org.testng.TestNG.run(TestNG.java:1007)
    at org.testng.remote.AbstractRemoteTestNG.run(AbstractRemoteTestNG.java:115)
    at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:251)
    at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:77)

1 Ответ

2 голосов
/ 09 апреля 2020

Вам нужен Stati c Блок инициализации или конструктор , чтобы вызвать super.readValues(). Сделайте это следующим образом:

Используя Stati c Блок инициализации:

public class Test1 extends BaseTest {
    String var1;

    {
        try {
            super.readValues();
        } catch (IOException e) {
            e.printStackTrace();
        }
        var1 = TestValues.VAR1;
    }

    @Test
    public void someFunction() throws InterruptedException {
        System.out.println(var1);
    }
}

Используя Конструктор:

public class Test1 extends BaseTest {
    String var1;

    Test1() {
        try {
            super.readValues();
            var1 = TestValues.VAR1;
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Test
    public void someFunction() throws InterruptedException {
        System.out.println(var1);
    }
}

Я протестировал оба решения для работать как положено. Не стесняйтесь комментировать в случае каких-либо сомнений / проблем.

Дополнительные примечания:

  1. Убедитесь, что у вас есть какое-то значение против ключа, VAR1 например VAR1=x в файле свойств.
  2. Я также предлагаю вам следовать Java соглашениям об именах например, class test1 должно быть class Test1 согласно соглашениям об именах.
...