-
Notifications
You must be signed in to change notification settings - Fork 26
OTST meeting minutes
Link to OTST Team Meeting
-
Demo environement : Sqills sandbox migration finalised, new credential, new end points. Communication was sent too users. Bileto delivered its sandbox. Can request access on osdm.cz for the moment. Josef will provide credentials this week.
-
First OTST scenario delivery : Tim run the first scenarion on Sqills Sandbox. Failiong on seat reservation request as supporting the selection with preference while Bileto support by seat number request. As a result to test both business logique, better to have a dedicated scenario per business function. Also Sqills identified that OSDM "collection" parameters were set in the Authentication" collection (not part of OSDM). Tim will propose changes to well split those 2 collections. Tim and Josef will work to fine tune the scenario in the next 2 weeks.
-
OSDM Validation Tool : Tim did a demo of the validation tool. It shown how to configre, run the scenario and what could be reported. Work in progress.
-
Next meeting : Due to member availability, next meeting is on the 24th of October
-
Demo environement : Sqill is migrating its demo environment to use its last aoolication version. The end poinbt to be used is changing. Tim will send communication to all Demo environement users. BILETO is finalising its Biletto demo environment delivery. As soon as ready, they will communicate.
-
First OTST scenario delivery : Josef delivered to Tim the first "workable" version of the scenario. Tim and Josef plan a commun test session next Monday. Status will be done next week.
-
OSDM Validation Tool : Tim is planning to do a demo potentially next week.
-
Scenario input variables setting : Josef upadted the OSDM collection to use a CSV input file pour setting the variable. He could not use the "legacy" POSTMAN way of integrate it, but got a way to do it. He could not finalise to do a demo during the meeting but should achieve it in next hours / day. As soons as finalised Josef will share it with Tim who will integrate it in Sqills validation tool to plan a demo as soon as possible.
-
OSDM starter collection : Josef created a dedicated collection in which he manage the authorisation (out side OSDM scope but required) and the OSDM collection setup up (like loading the necessary libraries). DIsucssion on the best way to structure the "starter" collection is not a structuring prioirity and is postponed
-
Postman scenario coding : Josef finalise its coding, and has now a separet "non OSDM" collection to request the Bileto token. This collection could be different for another environment (like Sqills sand box). This "Non OSDM" TOken collection must be run prior starting the OSDM collection.
-
Scenario input variables setting : Discussion on how to mange the input variables required to run the collection. For offer request using as input a trip description, the nummber pof legs, stops can be different from on provider to another. To ease the config set up Josef will have an external CSV file with generic variables defined that can be extended for example depending on the number of legs, etc (ref to postman doc https://learning.postman.com/docs/collections/running-collections/working-with-data-files/ ). His objective is to deliver it next week.
-
Next steps : Setup of the "OSDM standard" environment is not urgent, ^Subject to be tacklle when the fistscenario will be finalised. Once Josef will have deliver its final version of the scenario (using the trip as search criteria), the team will focuss on this one to enrich it with validation tests. Teh goal is to finalise this first scenario with all necessary validations tests before starting duplicating it for another type of Offer request scenario (based of O&D search) or based a a trip id.
- Postman scenario coding : Josef continue to improve his code. For the dev environnent, the proposal is to have it on Josef private environnent for the moment (Josef can give access to anyboduy willing to contribute)until we have a stabilised version which will be then loaded on the "OSDM stanadr OTST github" environnent that we need to define.
For the static javascript files, for the moment Josef use Digital Ocean and its automation to publish those JS files continuously upon each commit. We will have to define later one how to store them in an OSDM "standard" environement.
-
Postman scenario coding : Josef from Bileto with the support of Martion from Turnit implemented the Postman scenario using Javascript libraries based on Sayantan from Amadeus recommendations. They have running scenarios, but need more time to finalised. They expect to deliver a final version mid september. Hosting the library in github is not the most performant solution. They recommend to have a dedicated library hosting solution. Action : Check in which environment the OTST libraries should be hosted.
-
Postman scenarion enhancement : Once the code framework is ready, we could enhance the scenario content adding more validation tests in the scenarios. Action: Identify volonteers willing to work on validation tests integration.
- Postman scenario coding : Josef from Bileto started to work on coding based on Sayantan recommendation. He will work during the summer break to deliver a first version in september. Sayantan propose his support on request, by mail exchange or meeting if required.
- Postman scenario coding : Sayantan from Amadeus did a presentation on how he reorganised the Postman scenario using Javascript libraries and data definition at collection / scenario level. He could not finish coding the offer part but will continue for the next meeting. On their side OTST members will look at Sayantan proposal to discuss next week how it could be reused.
- Number of scenarios: Restart the discussion on the necessity to deplicate or not scenarios as all complexity is mainly in the offer response to be handled. Discussion postponed as priority done on the Scenario coding for the moment.
- All of the features require starting with obtaining an offer. It makes sense to create a collection just to issue offer based on different parameters. If doesn't fail, the offer id may be reused in use case-specific scenarios or re-run from the offer collection without further validation.
- Mapping different kinds of offers we actually need for the use cases (in env. variables)
- Josef also presented how railML certification is performed - the consultant provides "unknown data set" and then is able to query the system. This zeroes feature differences based only on products that different vendors/carriers offer and helps test same set of function features. For future discussion if OSDM APIs could also be tested this way,
Meeting Minutes:
- Direct booking scenario: Tim presented the scenario, and announced that mid next week, Sqills will have its sand box supporting OSDM V3. The scanario will be loaded on GITHIB during the week.
- Architecture of scenarios: Based on this first scenario, it is agreed it will be easier to managed a list of scenarios per function to validate rather than a unique scenario polymorphique.
Meeting Minutes:
- Direct Booking test scenario : Next steps (Tim / Josef) Due to Murphy law, Tim could not deliver the final version of the forst scenario. Hopefully next week.
- Admission Resa scenario : Updated by Martin on the script loaded on Github Martin did not progress. No updates.
- Exchange with Postman experts : Sayantan Roy from Amadeus) : Sayantan explained few solution he is using to managed Amadeus test scenario collection in a configurable / maintenable manner. Here are his top recommendations a) Handling Strict Variables via environment variables
b) For all test related variables utilize only global variables
c) For framework one can create it and utilize it via git repo and eval the code in each test
d) Using htmlextra for reporting while running through newman.
e) Using base tests to run different data sets.
To progress on the subject, P.Heuguet will produce a document summarizing OTST team objective allowing Sayantan to better understand what we are willing to achieve, and Tim will try to send befor next session his first scenario. Tim scenario is built on V3 version, and cannot run as such on the Sqills sandbox which is on V2 version. Potentially he will try to deliver a V2 version of the scenario
- Meeting hour change: To facilitate the access to the session it was decided to move it a 1:30 PM.
Agenda proposal:
- Direct Booking test scenario : Next steps (Tim / Josef) Tim is back from vacation. He did a demonstration on how it is developped to support different type of test scenarios like shopping with reduction card or without. and will try to deliver a first clean version of the scenario end of the week
- Admission Resa scenario : Updated by Martin on the script loaded on Github MArtin is working in paralell on its set of scenario, he will continue to invest on them and progress. The team agreed on the value at this stage to work in parallel on different way of developping , we will converge at a later stage.
- Insomia test collection : Presentation from Mattias Matthias tested Imsomia, but found it less mature, less stable than Postam Also he looked at the Postman JSON export capability allowing to manage the dev of OST scenarios in github. He confirmed after some test it is working well and it is stable.
- Exchange with Postman experts: Amadeus who is using extensively POstman propose to ahave an exchange with one of its expert next week. To better prepare the exchange OST team will share its first scenario in advance.
Turnit created a new scenario based on the initial scenario. The poll request is created Some issues to be solved . Some on the Turnit test environement and some other on the scenario improvment to be done with Josef / Tim. In Turnit scenario refund was changed adding the release seat step first. For the trip, should we use trip specification or trip search
How to use/manage variable naming convention and inventiory to be sure someone will not duplicate an existing variable.
- You can create variable at different level, Matthias Rainer had the issue as postman manage variable or at global level or at collection level. One way to solve is to have one scenario per collection.
- In this case, could we run the same collection multiple time in parallele ?
- Need to check with Sqills who is developping the Test apps using those scenarios.
- P.Heuguet asked if a postman expert could be helpfully fastracking the definition of the postman scenario architecture ?
- P.Ludwig propose to provide SBB dedicated apps developped in JAVA to developp the scenarios avoiding postman limitation on variable handling.
- Bileto proposed HTTPPIE must not at the same level than postman running scenarios in parallel. Missing features.
- Postman is widly use , thus securing support
- Could it be better in the paid version of Postman, from Mathias perspective, not really
- Mathias found a postman function 'random' taht could be used to have consistant testing. We can also import mibrary. Mathais will investigate
The first test case finalisation is pending ressource availability that are on cvacation. In standby for the moment.
Turnit could not deliver their test case this week due to workload. Will replan their delivery target
ÖBB will provide additional test scearios in a few weeks, exact target not yet finalised.
Due to ressources availability, there are delays in the targeted deliveries.
The first test case identified a small bug in the specification.
The first test case of Turnit will be ready next week.
ÖBB will provide additional test scearios in a few weeks.
Before teh start of the meeting, welcoming Patrick Ludwing representing SBB who is starting its OSDM implementation. Patrick coordinating SBB teams working on the subject.
1) Scenarios catalogue : Not addressed this week
2) Scenario configuration : Tim provided feed back on testing the scenario in his test environment. Main issue is about "request" in which potentially a railway could ask an optional field (as if it was mandatory). in the scenario tested the example was : productCategory in the offer request:
"service": { "productCategory": { "name": "{{service_type_name}}", "shortName": "{{service_type_name}}", "productCategoryRef": "urn:{{namespace_stations}}:sbc:{{service_type_brand_code}}" }, Discussions on different solution:
- Force anyone implementing to be in a positon to send response with request using only mandatory fields : Easiest way to solve the PB, not not sure it is posisble to impose this rule. To be discussed with the OSDM expert team on Friday morning. Patrick will raise the point to Andreas and Clemens.
- Analyse the error message to check that an optional field is missing to have the carrier managing the request: Not sure there qre OSDM rules defined to have such error message response. More chance to have a response "no offer available" rather than Mandatory field missing...
- Analyse all potential optional fields that should be used, and include them in the configuration capabilities to adapt the scenario depending on the Railway behaviour: Possible but adding more complexity in the scenario architecture.
Next steps : Tim will continue to test to check the scenario behaviour will propose some evolution to solve issues found and share its results with Josef to push on github e new version of the scenario that could be then enhanced by OSTST members to enrich its validation capability.
3) Scenario validation : Schema : Tim integreted it in the scenario prototype and will finalise its tests to validate and push the enhancement to Josef
4) Scenario validation : Content :
In standby until point 2 and 3 above will be finalised.
1) Scenarios catalogue :
No update done by the team this week, participants will try to find spare time to propose updates for next week.
The scenarios will try to be generic and flexible enough to check differents features in one scenarion. For example a sles scenarion includes offer/booking / fullfilment verbs and will be in capcity to validate different type of booking NRT with or without mandatory reservation / IRT
But some dedicated scenario will have to be done if in the middle of the process a new verb is used like a sale scenarion including a seat graphical reservation.
Same about after sale, as we have 2 different type of aftersales, full or partial refund.
Clemens will enhanced the document adding an excel file allowing that all OSDM verbs / features are covered by defined scenarios
2) Scenario configuration :
Josef updtaded github with the folowing updates:
-
Support OSDM V3
-
Decoupling the authentication process scenario which is out of OSDM scope from the OSDM scenario which only need the certification token
-
Removing all steps dedicated to BILETO specific elements
-
Environment include the setup of station code type, station code, carrier code
The scenario is a direct reservation, booking only the seat reservation.
Tim will test this week this version of the prototype and privide his feed back
3) Scenario validation : Schema :
TIM did a scenario testing the schema based on the GITHUB OSDM JSON schema reference file. WOrking fine. Before integrating it in the proto, Tim is willing to validate an "invalid" schema and check how the rport is done.
Once done the code will be shared with Josef to be integrated in the proto scenario.
4) Scenario validation : Content :
In standby until point 2 and 3 above will be finalised.
1) Scenarios catalogue :
Clemens created a new page listing the OSDM features and their type Mandatory, Conditional or Optional. Offer is not included as anyway a prerequite for a booking. Hidden feature in booking. Next step is to have the OTST team reveiwing the list and updating it if necessary.
2 questions addressed:
1- Should the first scenario should include conditional features ?
2- Should we integrate offer search as forst scenario is a direct booking use case ?
Those 2 will be further discussed in the way the prototype is developped.
Clemens also cretaed a JSON reference file on github for the V3.0.0. This file can be used to test JSON schema in OTST scenario. Clemens will start a draft proposal to define the content of the first scenario. This content will be updated based on the evolution of the prototype under development.
Action : OTST team to review the propose feature list and update it if necessary to have a final version Action : Clemens to propose a first draft version of the first scenario with its features.
2) Scenario configuration :
Josef started to test but had issues due to version differences. Decision : OTST focus on V3.0.0. No investment to be done to retrofit the V3 scenario for V2 version. As Skills has a local V3 version platform Josef will upload its last version of the scenario, and Sqills will test it on its local environment providing feedback on issues, and proosing also enhancements.
Autentification process. Difficult to make it configurable. **Decision :**The Autentification process is out of scope of OTST scenarios. The tester will have to provide as an input a valid token to run its OTST scenarios. It is recommended to have a token valid at least for more than 10mm to avoid issue.
Josef will focus on "domain" configuration URL end point, Station Code / Operator code type etc...)
3) Scenario validation : Schema :
AJV is a potential solution to test the schema. Sqills propose to integrate schema validation on its scenario, and to propose this enhancement for the prototype.
4) Scenario validation : Content :
For the content validation, we should take in account also process type of OSDM tech team recommandation (like the recommendation on NRT with mandatory reservation with price only in acco price or reservation price). OTST will implement a test to check the implementation is compliant with the OSDM expert team reco, and will report a warning with proposed alternate solution compliante with OSDM. Once the first prototype scenario will be ready, it is propose to share it with all team mebers allowing them to run it on their own environment and check if with the test they run on their side they can propose enhancements
Next OTST weekly meeting will then focuss on finalising this first proto scenarios.
1) 1st test scenario prototype delivery :
Some adaptation must be done on the scenario to manage fir API parameter, the Oauth version, and also in the request parameters like for exemple the station type parameter and try to make this configurable. Sqills and Bileto will work to continue the valiodation of the prototype on the Sqills environment. Decision : Sqills / Bileto to plan a dedicated meeting to review the scenario.
2) Sqills demonstration about a scenario running in postman console :
Based on the Sqill Sandbox demo scenarios, Sqills developp a proof of concept allowing to run a postman scenario chaining different request in sequence, testing their resuls and deliverying a report. Very promosing demo.
3) Catalogue of scenarios :
Discussion about the number of scenarios to be developped. Two ideas to ficus on the most important one's
- Focus on mandatory elements
- Focus on Pareto law (20% of the functions representing 80% of the volume)
Clemens proposed to start a doc on the scenario scope on the WIKI.
4) OSDM schema validation :
A first discussion on possible way to integrate in the scenario the validation of the OSDM schema. At least schema validation has 2 sides
- The format
- The content
A link to a postamn page explaining how to do a schema validation with postman was shared https://postman-quick-reference-guide.readthedocs.io/en/latest/schema-validation.html#
Few ideas shared like Converting the YML file in JSON and use it in postman, Using a Java script library. To be continued
4) Scenario solution architecture :
Return of experience from Turnit (Martin) who used in the past a library (https://unpkg.com/node-forge@1.0.0/dist/forge.min.js) as an environment variable. it dropped the performance significantly. Sadly no comparison available right now.
Discussion on the subject to be continued
1) 1st test scenario prototype delivery :
Josef Petrak from Bileto delivered the first version of the Direct Booking test scenario prototype. It is defined based on 2.0 OSDM specs. Will be migrated soon to V3.0 version.
Decision : The test scenarios will be based on version V3.0 of OSDM. Bileto, Sqills and Turnit will provide V3.0 test environment to test them
2) Test scenario configuration :
Some mandatory parameters should be configurable like
- End Point (the URN to target)
- Origin and Destination stations
- Hour of departure
- PAX info potentially with birth date or age depending on Railway behavior.
2 ways of entering the parameters
- Updating the parameters in the Postman environment ( current way)
- A script asking the parameters to the end user and updating postman config. Need some devs, maybe for a later stage
3) Scenario test report :
Action: Tim Van Berg from Sqills will test the 1st prototype on the Sqills Sandbox He will see what type of reporting can be produced based on the Postman result checks done.
4) Scenario solution architecture:
Postman cannot allow to have code done to support shared functions or libraries to avoid some copy/paste between the different scenarios.
Decision: the team agreed to keep Postman and live with its coding limitation and find solutions (like embedding a function to be stored in the environment). The focus is today on delivering the first test prototype. Once done this discussion will be reopen.
Discussion:
On top of the Functional (offer / Booking / Fullfillment, etc…) and Feautures ( Nbr of PAX, Reduction cards, Seat resa, Ancilaries…), there are other dimensions:
- Mandatory / Optional parameters
- Providers / Distributors
The focus is to do a validation of the OSDM Railways implemenation to re-inforce the message about the willingness of the sector to have a standardisation of their distribution. The priority is givent o this validation.
On the distribution side; the validation will be more diffcult as anyway it should be beyond only the exhange of messae bt more on the way the provider responses are used and displayed. It is out of scope of OTST
Catalogue matrix:
Two options are envisaged
- A full catalogue matrix listing all possible functionnalities / featured to be tested, and the Railways selecting the the cases he wants to validate.
- A minimum list of functions the provider wants to test (like Trips, Offers, Booking, Fullfilment, Refund all, Excnaheg All; Partial refund, Partial Exchange,….) that he is supporting.
Features are discovered by the scenario based on the offers responses, and tested automatically by the scenario. For example if the offers answer propose ancilaries, the scenario will try to book, fullfil those ancilaries.
The team decided to go for option 2 with the provider defining at the beginning the level on function coverage it supports and proposing in its test environnement the necessary data allwong to test the full ranges of features he wants to validate. It is the responsibility of the provider to secure its test environment is providing the level of data necessary to validate all the features he is willing o use on production.
The test scenarios will provide a report listing all features tested succesfully.
On some specific use cases like passenger type, the scenario, will test the 2 possible options (age or PAX type), in the report at least one of them should be succesfull. No need to define in advance wich one is used. The scenario will check automatically both options.
As a future enhancement, we could have as an input a matric of features the provider is willing to support and check that the test report is compliant with this wish list. This enhancement is out of scope of the OTST 2023 delivery scope
Conclusions: Catalogue matrix is limited to the list of functions the provider is supporting Test scenarios will detect which features are offered in the offer response and will validate them automatically, producing a report listing the features tested succesfully, and the one failing.
OSDM Wiki