How to read required key, values from json response and store it in json format using robot framework?

我与影子孤独终老i 提交于 2019-12-08 04:43:20

问题


I am trying to read the required key and values from JSON Response and store it in JSON file.

I have a sample simplified json format as below:

 ${API_Output}= {
"data": {
"resources": {
"edges": [
{
"node": {
    "tags": [],
   }
},
{          
  "node": {
   "tags": [
      {
        "name": "app",
        "value": "e2e"
      },
      {
        "name": "Cost",
         "value": "qwerty"
      }
  }
},
{          
  "node": {
   "tags": [
      {
        "name": "app",
        "value": "e2e"
      },
      {
        "name": "Cost",
         "value": "qwerty"
      },
        {
        "name": "test",
         "value": "qwerty"
      }
  }
}
]
}
}
}

Here, I am reading the tags name and value which are present. I have used the dictionary key "set to dictionary" but that prints only the last response of the tags.

I want to know how to append or add the data into the dictionary and store it in JSON format.

Robot code I have used:

 ${dict1}=        Set Variable  ${API_Output}
 ${cnt}=     get length     ${dict1['data']['resources']['edges']}
 ${edge}=   set variable      ${dict1['data']['resources']['edges']}

 run keyword if   ${cnt}==0     set test message    The resources count is 
  Zero(0)
  log to console  ${cnt}-count

: FOR    ${item}    IN RANGE   0    ${cnt}
 \    ${readName}=    Set Variable     ${edge[${item}]['node'] 
       ['configuration']}
 \    ${readvalue2}=    Set Variable     ${edge[${item}]['node']['tags']}
  \    ${tag_Count}=    get length     ${edge[${item}]['node']['tags']}
 \    ${tag_variable}=   set variable   ${edge[${item}]['node']['tags']}
 \    forkeyword       ${tag_Count}   ${tag_variable}    ${readName}

 ${req_json}    Json.Dumps    ${dict}
 Create File  results.json  ${req_json}


forkeyword
[Arguments]       ${tag_Count}      ${tag_variable}     ${readName}
@{z}=   create list
 : FOR    ${item}    IN RANGE   0    ${tag_Count}
     \   ${resourceName}=    run keyword if     ${tag_Count} > 0   set 
     variable    ${readName['name']}
     \   log to console  ${resourceName}-forloop
     \   ${readkey}=     set variable   ${tag_variable[${item}]['name']}
     \   ${readvalue}=     set variable   ${tag_variable[${item}]['value']}
     \   set to dictionary     ${dict}     resourceName   ${resourceName}
     \   set to dictionary  ${dict}    ${readkey}     ${readvalue}
 set suite variable ${dict}

Output is in Values.json file I get only last tags values.

        {
        "name": "app",
        "value": "e2e"
      },
      {
        "name": "Cost",
         "value": "qwerty"
      },
        {
        "name": "test",
         "value": "qwerty"
      }

But, I need all the tags values of both tags. Can anyone guide me on how can I use a dictionary or list keywords? to store all tags' response in the file. I am newbie to robot framework so I apologies if I made any mistake.

来源:https://stackoverflow.com/questions/58797352/how-to-read-required-key-values-from-json-response-and-store-it-in-json-format

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!