Groovy Нет такой ошибки свойства при создании динамического JSON

Я пытаюсь создать динамический JSON с использованием данных CSV в Jmeter с препроцессором JSR223

Ниже приведен код для того же я использую CSV для данных для Id и Name:

def builder = new groovy.json.JsonBuilder()

@groovy.transform.Immutable
class Items {
    String Id
    String Name
}

def items = new File("Item.txt").readLines().collect { line -> new Items(line.split(",")[0], line.split(",")[1]) }
builder.Rule(

        __type: "DataCollectionRule",
        DeviceFamily: '${__P(DeviceFamily)}',
        RuleId: 0,
        Name: 'test-${__time(yyyy-MM-dd'T'hh:mm:ss)}-${__counter(TRUE,)}',
        Targets:
                [
                        Groups :
                                [
                                        [
                                                Id: '${logicalid1_1}',
                                        ]
                                ],
                        Devices:
                                [

                                ]
                ],
        StartDate: '/Date(${__time(,)})/',        
        IsEnabled: true,
        Priority: 0,
        AlertType: 0,
        DeliverySchedule:
                [
                                                Id         :   1,
                                                Name       :  "Every 30 Minutes",
                                                Period     :  "30M"

                ],
        CollectionSchedule:                      
               [
                                              Id         :   1,
                                                Name       :  "Every 30 Minutes",
                                                Period     :  "30M"
              ],                    
        Items  : items.collect() [
        [

                                                Id         : it.Id,
                                                Name       : it.Name                                                

        ]
                ],
        LocationAccuracy:
                [
                                                UseGPS     :  false,
                                       DistanceInMeters : 100,
                                       ReportToServer  : true,
                                       AccuracyInMeters : 10
             ],
          HasDolphinCounters: false,
          EnrollmentCertificateId: null,
          EnrollmentCertificateName: "",
        DatabaseHighWatermark: 28,
        DatabaseLowWatermark: 14,
        DeviceHighWatermark: 400,
        DeviceLowWatermark:  200

)

sampler.getArguments().removeAllArguments()
sampler.addNonEncodedArgument('', builder.toPrettyString(), '')
sampler.setPostBodyRaw(true);

Во время выполнения теста я получаю HTTP 400 с ошибочным запросом

Сообщение журнала показано ниже:

2018-09-24 13: 49: 23,669 ОШИБКА oajmJSR223PreProcessor: Проблема в скрипте JSR223, препроцессоре JSR223 javax.script.ScriptException: groovy.lang.MissingPropertyException: Нет такого свойства: это для класса: Script32 в org.codehaus.gro3y.s.GroovyScriptEngineImpl.eval(GroovyScriptEngineImpl.java:320) ~[groovy-all-2.4.13.jar:2.4.13] в org.codehaus.groovy.jsr223.GroovyCompiledScript.eval(GroovyCompiledScript.java:72) ~[groovy-all-2.4.13.jar:2.4.13] в javax.script.CompiledScript.eval(неизвестный источник) ~[?:1.8.0_151] в org.apache.jmeter.util.JSR223TestElement.processFileOrScript(JSR223TestElement.java:221) ~[ApacheJMeter_core.jar:4.0 r1823414] в org.apache.jmeter.modifiers.JSR223PreProcessor.process(JSR223PreProcessor.java:44) [ApacheJMeter_components.jar:4.0 r1823414] в org.apache.JetterMjter..java:849) [ApacheJMeter_core.jar:4.0 r1823414] в org.apache.jmeter.threads.JMeterThread.executeSamplePackage(JMeterThread.java:467) [ApacheJMeter_core.jar:4.0 r1823414] в org.apache.jmeter.threads.JMeterThread.processSampler(JMeterThread.java:416) [ApacheJMeter_core.jar:4.0 r1823414] в org.apache.jmeter.threads.JMeterThread.run: JMej) [ApacheJMeter_core.jar:4.0 r1823414] at java.lang.Thread.run(неизвестный источник) [?:1.8.0_151] Вызывается: groovy.lang.MissingPropertyException: Нет такого свойства: это для класса: Script32 в org.codehaus.groovy.runtime.ScriptBytecodeAdapter.unwrap(ScriptBytecodeAdapter.java:53) ~[groovy-all-2.4.13.jar:2.4.13] в org.codehaus.groovy.runtime.callsite.PogoGetPropertySite.get.perperty: PogoGetJ 52) ~[groovy-all-2.4.13.jar:2.4.13] в org.codehaus.groovy.runtime.callsite.AbstractCallSite.callGroovyObjectGetProperty(AbstractCallSite.java:307) ~[groovy-all-2.4.13.jar:2.4.13] в Script32.run(Script32.groovy:46) ~[?:?] В org.codehaus.groovy.jsr223.GroovyScriptEngineImpl.eval(GroovyScriptEngineImpl.java:317) ~[groovy-all-2.4.13.jar:2.4.13] ... еще 9

CSV выглядит следующим образом:

   -1,BatteryStatus
    -3,AvailableMemory
    -5,AvailableStorage

заранее спасибо

2 ответа

Вы должны использовать {} для закрытия здесь:

items.collect() { // wrong: [
    // ...
} // wrong: ]

Или просто items.collect { ... }

С [] компилятор увидит это как литерал карты и вы получите ошибки выше (it не определено)

Я считаю, что вы должны более точно копировать и вставлять пример кода, чтобы ваш раздел "Элементы" выглядел следующим образом:

Items: items.collect() {
    [
            Id  : it.Id,
            Name: it.Name
    ]
}

Также следует помнить, что не следует использовать функции JMeter и / или переменные в скриптах Groovy напрямую, поскольку это конфликтует с функцией шаблона GString и делает невозможным кэширование скомпилированных скриптов, негативно влияющее на производительность.

Поэтому я бы также порекомендовал изменить:

  • ${__P(DeviceFamily) в props.get('DeviceFamily)`
  • ${__time(yyyy-MM-dd'T'hh:mm:ss)} в new Date().format("yyyy-MM-dd'T'hh:mm:ss")
  • и т.п.

Обратитесь к разделу Шпаргалка шаблонов Groovy для JMeter для получения дополнительной информации о скриптах Groovy в JMeter, если это необходимо.

Другие вопросы по тегам