Forum Discussion
Can you provide more information please. I assume you were making an API call and that's why you got a 502 server message. What was the URL you were using, etc.
- Hey Mahesh9100,
Yes this is totally feasible and in fact is the way i build all my readyapi projects now.
The way i do this is that i create a ptoperties file that contains my environment specific static data, such as URLS, token values, username/password values and within this properties file i have placeholder property names (without the values populated) for all my dynamic data that is environment specific such as GUIDs etc.
I create one of these properties files for each environment.
Before execution i determine which environment is being tested and i then load in the properties file (which creates custom project level properties....as i already stated...the static data properties and values specific to the environment and empty/blank custom project level property placeholder names).
Once the file is loaded in, i then have some disabled testsuites that execute queries against the environment to populate those dynamic data values (that are environment specific).
Within my project i then create my normal functional testsuites (that are enabled) to exercise my tests, but the first testcase includes a single "Run Testcase/teststep" that executes the disabled testcase that generates the dynamic data (this wa the dynamic testdata never has the chance to expire). The remainder o my testcases are normal testcases except they alwaya reference the custom level project level properties for the all environment specific detail.
The above works really well and do it or every single readyapi project i create now. Alas i cant take credit for this approach. It was nmrao who showed me how to do this and it works like a charm.
Obviously this cant be the only way of doing this, but this approach works so well for me, ive never bothered using any other or even learning any other approach.
Cheers
Richrichie Thanks for your detail explanation.
Could you please let me know how the assertions are implemented in your case?
Thanks in advanced.
- There is feature exist called Environment where one can define different environments as you mentioned. One can choose environment during test execution.
However, IMO, the test request and response and assertions would be the same.
Would you please provide the use case with the details how it is different ?Thanks Rao for the reply.
I have tried the Environment feature but what it does is change the your base URL and I couldn't find a way to change the test data and assertions based on the selected environment.
Use case
There is an API to retrieve person data. I wanted to run the same in Dev, UAT and pre-prod environments. But the databases are different(dev person id- 100 is different with UAT person id- 100(two different persons)). As a result of it , the name I wanted to assert in dev is different with the name in UAT.
Therefore I just wanted to know whether it is feasible to do this with a single Test suite or I need multiple suites for each environment since the databases are different.
- Here is the thread with details regarding usage of different environments with just properties (what richie was referring to)
https://stackoverflow.com/questions/37655778/soapui-ability-to-switch-between-database-connections-for-test-suite/37659250#37659250
NOTE: the above approach doesn't require to use Environments feature yet it is simple and flexible.
Related Content
Recent Discussions
- 3 hours ago