As NowYoYo® have been working on OTS for some time, it was necessary for us to build our own HUB in the absence of one from TOTSCo. In addition, we are able to spin up multiple Residential Commuinication Provider (RCP) endpoints that can operate as good and bad RCPs. This means we can establish an RCP with poor data quality as a unique set of matching practices which allows our clients to test against these patterns.
As we know, 95-98% of households already have broadband, and so this suggests that a high proportion of consumers will use the OTS process. Without a successful match a sale can not be processed if the consumer wishes to use OTS to seemlessly switch services between providers.
By building a series of RCPs that mirror some of the characteristics  we can ultimately help others and train agents to get first-hand experience in handling more challenging edge cases and build guidance on the next-best-actions. This  helps with training and makes agent and digital journeys much more robust to some of the challenges that OTS can through at both the Gaining and Losing Providers.
We have recently introduced our own dedicated RoaR Test RCP (RCWV) which support multiple tenancies and can be used by any other RCP to test their deployment at part of UAT pre-production testing.  This test RCP, support both Syncronhous and Asyncronhous message testing, Audit Data, HUB responses and provides the ability to create challenging customer assets with multuple circuits at the same address, common Account numbers and even apply commerical/technical rules for force-cease, option-to-retain and option-to-cease which are often over looked when peforming switch matches if locally you dont support these options.
Industry consistency is key to the sucess and testing with a common baseline and diverse CPs is key to ensuring any issues are spotted and discuss with TOTSCo before going live.  We hope that the tools we provide can go some way to supporting this model.
Register users:
A Group of emails (could be by domain) will be registered under a specific Brand (RCPID). Partitioning of access through sub-account
When used as GRCP: 
Users can only send messages to the registered brand(s) as these will be the only ones they see in the directory.
This ensures that each CP does not see the other’s messages when testing, both at the interaction level (associated messages related to a switch type) and at the Audit (detailed logging).
Users can see the Full Audit Log at their own CP level and NYY, thus removing the need for TOTSCo and the service desk to be engaged, as both sides can be viewed without dummy RCPIDs.
When used as LRCP:
A. Synchronous Message Responses: Using predefined surnames, e.g. “FourHundredAndTwo”, NYY will respond with that specific HTTP Code and attempt to pass specific payloads back to the HUB.
Current Change request submitted to TOTSCo: The passing of the payload is significant so that CPs can signal to each other why they have rejected a specific message and self-heal.  Having the HUB strip this and replace it with a generic 9006 or 9008 message means the intelligence has been lost. If we can pass the body, then the Service Desk would not have to be engaged in understanding the rejections, which would drive down the cost-to-service for TOTSCo/industry.
B. Force AuditData Responses: By sending appended surnames, AuditData can be inserted into the envelope.This helps with testing HUB validation and the ability to handle these messages.
C. Canned Responses: As standard, we can match a specific UPRN to an Asynchronous Response Code.
This allows CP to check and ensure they can handle all Response codes with the next best actions.
D. Switch Match Delays: To make the LRCP challenge slightly more complicated, we can insert delays into the response so that GRCP can test latency.
This can be done at a common level (fixed and random) and fixed latency based on specific UPRNs.
This helps with Digital journey development to check presentation layers, agents and end consumer screens can handle delays.
E. Customer Assets:
A set of Customer Assets can be created to mirror good and bad stored customer details.
This allows a high degree of flexibility in storing good & bad address data, e.g. having multiple accounts with the same surname in the same house and testing different entity models.
Data can include UPRN, errors in UPRNs, and conflicting address details.
We can even add different commercial rules to each customer, which allows the algorithm to return different SOR options based on the technical/commercial setup of that company (forced Cease vs. OptionToCease/ OptionToRetain) and thus enable a CP test outside of their own commercial rules to check they can handle this.
When resolving complex matching, OTS response codes will be returned per the matching algorithm to help guide agents and the system with the next actions.  This means that CPs will experience unhappy Switch Matches and ensure that their training and systems can handle the matching of data stored (shown on the invoice) and not what OS data might say when you look at a postcode.
F. Switch Orders: 
As new Orders come in from the CPs acting as a GRCP, the NYY system can manually confirm or reject with a specific response code to all orders, updates, cancels and triggers so that CPs can test when confirmations are not returned within the SLA or response are returned that they were not expecting. These features allow CPs to do some negative testing when a CP is a bad actor and ensure they can handle this at system, agent, and digital journey levels.
We currently operate this over two environments.
SIT – System Integration Testing - which operates over the NowYoYo HUB and is used to iterate, and this could be extended, if required, directly to other CPs if at the early stage of development.
UAT – User Acceptance Testing – This utilises the pre-production TOTSCo Hub and is thus ideally suited and is also available 24/7.