Изменение способа, которым моя программа принимает файлы, создаст эту ошибку из GSON: ожидается BEGIN_ARRAY, но был ли BEGIN_OBJECT в строке 1, столбце 2, пути $?
По этой теме было задано много вопросов, но этот вопрос отличается, потому что способ, которым я определяю определенную переменную, определяет, будет ли выброшена эта ошибка.
По сути, у меня есть файл JSON ниже:
[
{
"appiumVersion":"1.8.1",
"buildTag": "build-0",
"newCommandTimeout": "30",
"deviceName":"Samsung Galaxy S9 WQHD GoogleAPI Emulator",
"deviceOrientation":"portrait",
"browserName":"",
"platformName":"Android",
"platformVersion":"7.1",
"app":"sauce-storage:ApiDemos-debug.apk"
},
{
"appiumVersion":"1.8.1",
"buildTag": "build-0",
"newCommandTimeout": "30",
"deviceName":"Samsung Galaxy S9 WQHD GoogleAPI Emulator",
"deviceOrientation":"portrait",
"browserName":"",
"platformName":"Android",
"platformVersion":"7.0",
"app":"sauce-storage:ApiDemos-debug.apk"
}
]
Я использую GSON для его анализа, и вот код для этого:
File capsJsonFile = new File(capsFilePath);
Reader capsReader = null;
try {
capsReader = new FileReader(capsJsonFile);
} catch (FileNotFoundException e) {
e.printStackTrace();
}
Gson gsonCapsJsonArr = new Gson();
JsonObject[] capsJsonArr = gsonCapsJsonArr.fromJson(capsReader, JsonObject[].class);
Затем у меня есть другая программа, которая вызывает вышеуказанный код:
capsFile = "C:\\Users\\exue\\IdeaProjects\\j-mobile\\tests\\src\\test\\resources\\capsJsonArray.json";
AutomationFramework.setCapsFilePath(capsFile);
И этот код устанавливает переменную "capsFilePath" равной "capsFile".
Что странно, если я напишу программу, как это, у меня нет ошибки. Но я хочу передать эту строку capsFile как системное свойство через плагин maven-surefire, который я использую для запуска этой программы, например:
capsFile = System.getProperty("capsFile");
AutomationFramework.setCapsFilePath(capsFile);
Я настроил плагин так:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.0</version>
<configuration>
<parallel>classes</parallel>
<threadCount>4</threadCount>
<redirectTestOutputToFile>false</redirectTestOutputToFile>
<systemProperties>
<property>
<property>
<name>capsFile</name>
<value>C:\\Users\\exue\\IdeaProjects\\j-mobile\\tests\\src\\test\\resources\\cfgJsonFile.json</value>
</property>
</systemProperties>
</configuration>
</plugin>
Написав это так, взяв файл как системное свойство, я теперь получаю эту ошибку:
[Utils] [ERROR] [Error] com.google.gson.JsonSyntaxException: java.lang.IllegalStateException: Expected BEGIN_ARRAY but was BEGIN_OBJECT at line 1 column 2 path $
at com.google.gson.Gson.fromJson(Gson.java:939)
at com.google.gson.Gson.fromJson(Gson.java:865)
at com.transunion.qecop.automationframework.AutomationFramework.mobileDeviceDataProvider(AutomationFramework.java:208)
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:124)
at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:74)
at org.testng.internal.MethodInvocationHelper.invokeMethodNoCheckedException(MethodInvocationHelper.java:45)
at org.testng.internal.MethodInvocationHelper.invokeDataProvider(MethodInvocationHelper.java:131)
at org.testng.internal.Parameters.handleParameters(Parameters.java:706)
at org.testng.internal.ParameterHandler.handleParameters(ParameterHandler.java:49)
at org.testng.internal.ParameterHandler.createParameters(ParameterHandler.java:37)
at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:924)
at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:125)
at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:109)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.IllegalStateException: Expected BEGIN_ARRAY but was BEGIN_OBJECT at line 1 column 2 path $
at com.google.gson.stream.JsonReader.beginArray(JsonReader.java:350)
at com.google.gson.internal.bind.ArrayTypeAdapter.read(ArrayTypeAdapter.java:70)
at com.google.gson.Gson.fromJson(Gson.java:927)
... 19 more
Но если я просто жестко закодирую строку, то эта ошибка не возникает. Как способ, которым я кормлю файл, может вызвать эту ошибку?
1 ответ
Причиной этой проблемы является то, что вы имеете в виду два разных JSON
то, что вы передаете в строке - это capsJsonArray.json
тогда как тот, который вы передаете в Maven, это cfgJsonFile.json
Я думаю, что проблема заключается в том, что JSON судят, поскольку это может быть неправильно