Genesys Cloud - Main

 View Only

Discussion Thread View
Expand all | Collapse all

To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

  • 1.  To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 11-11-2022 10:05
    I have been pondering this for many moons and would like to elicit input from the community to try and discover a common consensus on when to use separate ORGs and when to use Divisions when a customer needs to have a development system.  The usual case is they want a sandbox for development, a place to test UAT, and limited access to production.  Of course, we all know the hassles of different ORGs (and costs) and CX as Code is just not quite there, especially if you don't have a team that manages your Terraform.  We usually suggest Divisions for this unless they want to test beta code outside of production.  So, let's discuss! 

    What do you recommend from your experience of how to deal with the need for DEV, UAT, and PROD environments in Genesys Cloud CX?
    #Implementation
    #PlatformAdministration
    #SystemAdministration

    ------------------------------
    Robert Wakefield-Carl
    Avtex Solutions, LLC
    Contact Center Innovation Architect
    https://www.Avtex.com
    https://RobertWC.Blogspot.com
    ------------------------------


  • 2.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 11-11-2022 10:58
    Edited by Paul Simpson 11-11-2022 10:58
    I'm interested in the community's views on this as well.

    One thing that can be a particular challenge is evaluation the impact of global settings, which is impossible to do with zero production impact risk without multiple ORGs!

    I feel that both options are equally problematic. The Division approach seems to be the most cost effective, but I see a lot of cases where Production / Development components "bleed" into each other, thus risking Production whilst development is in progress. (I most often see Development entities, such as Tables or Scripts, referenced from Production Flows and Queues. I also have seen some horrific scenarios where multiple flows interact (Common Modules, In-Queue Flows, Flow transfers etc.) where the amount of editing post-development (and testing!) to align almost invalidates UAT!

    And let's not even start on development for / with the API!

    I feel that Genesys needs to address this issue. We need access to low-cost "development" ORGs. and the ability to do a complete "lift and shift" between ORGs. (I appreciate the former would incur some AWS cost and the latter is complicated by GUIDs and so on) but as customers become more reliant on Genesys Cloud "just working", it's going to become lass and less acceptable to risk outages whilst performing enhancements.

    This is one area in which PureConnect definitely has the advantage! Being Premised-based obviously helps, but....

    Just my 10 cents.

    ------------------------------
    Paul Simpson
    Eventus Solutions Group
    ------------------------------



  • 3.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    GENESYS
    Posted 11-11-2022 17:12
    From my 6 years as a partner and now my time here at Zillow, I've found that there is not a single direction to go on this one -- even between teams/LOB within one org. I do my best to use a separate division, throwaway phone number etc to handle UAT within our primary org because I hate org-hopping from prod to dev to make little tweaks to a test flow for a team BUT then on the other side we have one LOB who does a lot via the API and with global settings that drives us to also have a 2nd org just for this LOB to do Dev/UAT work in and on the backend I eat it by having to export/import flows and tables across orgs and update all the broken references to queues and skills. I have been trying to use the 'Find X' functions in Architect as much as possible so that I can avoid hard-references to items in my flows, making it easier to import across orgs as long as my base objects are named the same.

    ------------------------------
    Brad Murlin
    Zillow, Inc.
    ------------------------------



  • 4.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 11-14-2022 07:46
    Brad,

    I feel your pain.

    Not only is this annoying and time-consuming, but also opens you up to the possibility of introducing bugs post-testing. I know this is caused by everything being referenced by GUID "behind the scenes", but if Genesys could at least provide an option during import to either auto-resolve based on name, or display all the discrepancies (and offer a suggested auto-resolution based on name) I think we could avoid potentially disastrous outcomes! 

    Maybe I need to submit an idea....

    ------------------------------
    Paul Simpson
    Eventus Solutions Group
    ------------------------------



  • 5.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    GENESYS
    Posted 11-14-2022 11:24

    For the flow import/export, use Archy.  When creating/updating the flow it resolves all the references by name not ID so it's great for moving between a testing & real org.


    https://developer.genesys.cloud/devapps/archy/

    The UI can export the flow as yaml, but you need to use archy for the import.

    https://help.mypurecloud.com/articles/define-architect-flows-using-yaml/



    ------------------------------
    Melissa Bailey
    Genesys - Employees
    ------------------------------



  • 6.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 11-14-2022 17:51
    Archy helps for flows with queue and user transfers, but what about common modules, data actions, bots and the like?

    ------------------------------
    Robert Wakefield-Carl
    Avtex Solutions, LLC
    Contact Center Innovation Architect
    https://www.Avtex.com
    https://RobertWC.Blogspot.com
    ------------------------------



  • 7.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 11-15-2022 08:02
    Archy will also be able to work for Common Modules to import it on to GC, bots i'm not sure, have not tested it.

    ------------------------------
    Ramu P
    Global Technology Solutions, LLC
    ------------------------------



  • 8.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 11-15-2022 08:20
    I think the concern here is not the ability to export / import these, but whether the references from other flows are properly resolved.

    Also, whilst it's great to have a tool, I believe it would be much better if this functionality were incorporated into the standard import.

    ------------------------------
    Paul Simpson
    Eventus Solutions Group
    ------------------------------



  • 9.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 11-16-2022 22:23
    Another question related to this.  How far has CX as Code come and how far is it from being the tool we need for synching or escalating between ORGs?  I know last I looked, it would only handle about 60% of the sync and was lacking in escalation between Dev and UAT/Production.   Who has experience with that and how it compares with the Division approach?

    ------------------------------
    Robert Wakefield-Carl
    Avtex Solutions, LLC
    Contact Center Innovation Architect
    https://www.Avtex.com
    https://RobertWC.Blogspot.com
    ------------------------------



  • 10.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    GENESYS
    Posted 11-28-2023 17:07

    Robert, 

    With the developments Genesys has made in the last year since you sparked this conversation, I'm interested to know -- how have your views/experiences changed on this topic in the last year?



    ------------------------------
    Zach Dudek
    Genesys
    ------------------------------



  • 11.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 05-15-2024 12:57

    I'd be interested to hear of any updates as well. We are currently having this discussion as we plan our migration to the cloud.



    ------------------------------
    Kristan P.
    ------------------------------



  • 12.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 05-16-2024 03:08

    We are currently using CX as Code to move configuration between 4 different Orgs. A few hurdles along the way and we're still in the process of getting it to where we want it to be however I would say it's been a success so far. Most GC objects are supported now and Genesys seems to update the provider every couple of weeks with new functionality, bug fixes etc 



    ------------------------------
    Savino Ricci
    Computacenter (UK) LTD
    ------------------------------



  • 13.  RE: To Division or not to Division - what is the correct way to handle Dev/UAT/Prod

    Posted 15 days ago

    Having done some work recently on another vendor's systems, I saw an interesting approach to this. As things stand, it can't be used in Genesys Cloud, but if this idea were to be implemented, it would work.

    The basic idea is to have all objects named with a consistent convention, where part of the name (say a suffix) is "Dev", "UAT" or "Prod". By allowing ALL objects to be referenced via an expression / variable, you can set a variable at the start (say, Flow.Env) and whenever referencing anything (say a Common Module, or an In_Queue Flow) you use an expression like "Flowname"+Flow.Env.

    I am aware that something like this could be achieved using Switch statements, but that is clunky and also means that, strictly speaking, the code being pushed to production is not the same as that which was tested (albeit a very small difference.)

    The idea of using CX as Code is interesting, but it does (I think?) assume separate ORGs, which not everyone has. Alternatively, it requires the exported configurations to be edited prior to re-import in order for all the references to get updated, which again introduces the possibility of errors.



    ------------------------------
    Paul Simpson
    Views expressed are my own and do not necessarily reflect those of my employer.
    ------------------------------



Need Help finding something?

Check out the Genesys Knowledge Network - your all-in-one access point for Genesys resources