Changes for page Testing in eMagiz
                  Last modified by Erik Bakker on 2024/08/08 11:24
              
      
      From version  28.1 
    
    
              edited by Erik Bakker
        
on 2024/08/08 11:22
     on 2024/08/08 11:22
      Change comment:
              There is no comment for this version
          
         
      To version  4.1 
    
    
              edited by Bouke Reitsma
        
on 2023/07/05 10:37
     on 2023/07/05 10:37
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. ebakker1 +XWiki.BoukeReitsma 
- Content
-   ... ... @@ -1,90 +1,73 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 -In this fundamental ,wewillexplorehevarioustestingfunctionalities availablewithinthe eMagiz portal. Wewilldelveintodifferenttypes oftesting,includingunit testing,regressionsting,performancetesting,andend-to-endtesting,anddiscusshowthesetestingmethodsareintegrated within the eMagizplatform.Let'sdive intothedetailsofeachtestingmethodandunderstandhowtheycanbeeffectivelyappliedto ensuretheefficiencyandreliability of yourintegrations.2 +In this fundamental we discuss different testing methods available in software development and discuss how these methods can be used and/or implanted within the platform. Testing in eMagiz can already be done within the Create phase and within deployed integrations via the Deploy and Manage phases. After reading this fundamental you should be able to understand the concepts of different testing methods and how these are incorporated within the eMagiz platform. 3 3 4 -Should you have any questions, please get in touch with [[academy@emagiz.com>>mailto:academy@emagiz.com]].4 +Should you have any questions, please get in touch with academy@emagiz.com. 5 5 6 6 == 1. Prerequisites == 7 7 8 -* BasicKnowledgeof the eMagizPlatform8 +* An overall view of the capabilities of the eMagiz platform will be helpful 9 9 10 10 == 2. Key concepts == 11 11 12 -* Unit Testing 13 -* Regression testing 14 -* Performance Testing 15 -* End-To-End Testing 12 +* eMagiz offers various options to trace messages across the platform 13 +* The three most noteworthy options are 14 + * Queue Statistics 15 + * Data Sink 16 + * Long Term Archiving 16 16 17 -== 3. Testing in eMagiz == 18 18 19 -Here we will investigate the testing functionality incorporated within the eMagiz portal. We will focus on different aspects of testing that can be executed at different moments within the development of your integrations. We cover four different types of testing that are part of software testing in general and explain them on a conceptual level. For each test, we also discuss how those are integrated within the portal and where to find further explanations on applying those tests within eMagiz. 20 20 21 -== =3.1Unittesting ===20 +== 3. Traceability in eMagiz == 22 22 23 - Unittestingisa common practice withinsoftware platforms.Usually,developersperformunittestsduringdevelopment.It entails testingindividualintegrationsor thecomponentswithinan integration,suchastransformations ormappings.The unit testaimsto test earlywithinthedevelopmentprocesstoidentifyand fixissuesearlybeforetheybecomemorecomplexandcostlytofindandsolve.22 +This fundamental will zoom in on which traceability concepts we have incorporated within the eMagiz portal to ensure that data travels from A to B. We will focus on traceability from three perspectives. At first, we zoom in on whether a message has been sent from A to B. Secondly, we determine whether a specific message has been dispatched from A to B. Thirdly, we focus on proving that the message was indeed sent years after a message has been sent. After this journey, you should have a solid understanding of which options eMagiz offers to trace messages between various systems across the integration platform. 24 24 25 - WithineMagiz, we have a dedicated unit testing functionality called "flow testing."One of the key benefits of flow testing is that your integration does not have to be deployed. Therefore, findings can be easily implemented during development.eMagiz supports live testing of certain components to test communication with externalsystems. Moreinformation on flow testscan be found in the following microlearnings:24 +=== 3.1 Queue Statistics === 26 26 27 -* [[Understanding Flow Testing>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-understanding-flowtesting||target="blank"]] 28 -* [[Configuring Flow Testing>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-configuring-flow-test||target="blank"]] 29 -* [[Create Test Message(s)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-creating-test-messages||target="blank"]] 30 -* [[Running A Flow Test>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-running-flow-test||target="blank"]] 31 -* [[Edit Test Message(s)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-editing-test-messages||target="blank"]] 32 -* [[Deleting Test Message(s)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-deleting-test-messages||target="blank"]] 33 -* [[Testing API Gateway>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Testing API Gateway.intermediate-testing-emagiz-api-gateway-testing-api-gateway||target="blank"]] 26 +In the Manage phase of eMagiz, we collect statistics to determine whether a message has been sent from one system to another. For example, we have the queue statistics for messaging and API Gateway. In this overview, you can zoom in on a specific queue and see the number of messages sent within that timeframe, the number of messages in the queue at a particular time, and whether or not messages are consumed at a specific moment in time. See below for an illustration of this concept. 34 34 35 - === 3.2 RegressionTesting===28 +[[image:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz--queue-statistics.png]] 36 36 37 - Anothertestingmethod usedwithinsoftware developmentisregressiontesting.Regressiontestsnsurethat existingfunctionalityis notimpactedby newlydevelopedfunctionality. Runningthesetests iscrucial to preventingunexpectednegativechangesforcustomers. Regressiontestscanbe appliedondifferent levels,fromindividualfunctionalityto thewholeplatform.30 +With the help of this overview, you can determine that a queue has processed a message at a specific moment. However, the statistics do not tell you anything about the content of the data. For most use cases, this is sufficient as the fact that a message has been sent is proof that the receiving application has received the data and can be found in that application. 38 38 39 - Themain functionality within theeMagiz platformo perform regressiontestingonyourintegrationscalled"Automatedflowtesting."There isanoption to automate every flow test. Whena flow test isutomated,it will runllautomatedflow tests oncenew versioncommitted.If thetest fails, youwill benotified of the flow levelandget anoverview ofthesultonrelease activation. More informationcan befound inthe microlearning:32 +For more information on queue statistics please check out the following [[Crashcourse Messaging>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Messaging.crashcourse-messaging-interpreting-queue-statistics||target="blank"]] 40 40 41 - *[[RegressionTesting>>doc:Main.eMagizAcademy.Microlearnings.IntermediateLevel.TestingineMagiz.intermediate-testing-in-emagiz-regression-testing.WebHome||target="blank"]]34 +In some cases, however, more traceability is needed for Ops work. For those use cases, we have additional functionality within eMagiz called data sink. 42 42 43 -=== 3. 3Performance Testing===36 +=== 3.2 Data Sink === 44 44 45 - Athird methodfortestingis theperformancetest.Within aperformance test,not thecontentisimportantbuttheamountfloadyoutest onyourtestsubject.Inthecaseofintegrations,it means,in general,thenumber of messagessentoveracertainintegration. Normally,your productionenvironmenthandlesmore loadthana testoracceptance environment.Withaperformancetest, you canestimate how much impactnewintegrationhas onresources,such asCPU ormemory usageoftheruntimeswithinyournvironment.Moreinformationon howto configurethesolutionarchitecture ofyourmodel canbe foundin thismicrolearning:38 +On top of the standard Manage functionality in eMagiz, you can acquire additional functionality that allows you to sink data at any given point in the flow into a bucket hosted by eMagiz. We advise you to do this twice per integration. Once when the message enters the eMagiz platform and once the message leaves the eMagiz platform. By providing a unique identifier (i.e., an order number), you can search through this data for maximum 180 days (minimum 30 days) to determine whether a specific message with a particular identifier is indeed received and/or delivered by eMagiz in the Manage phase of eMagiz. See below for an illustration of this functionality. 46 46 47 -* [[Intermediate Solution Architecture>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Solution Architecture.WebHome||target="blank"]] 48 -* [[Advanced Solution Architecture>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Solution Architecture.WebHome||target="blank"]] 40 +[[image:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz--data-sink-view-manage.png]] 49 49 50 - {{warning}} Performancetesting onhe eMagizor documentation portals **not**allowed. {{/warning}}42 +[[image:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz--data-sink-search-options.png]] 51 51 52 - === 3.4 End-To-EndTesting===44 +[[image:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz--data-sink-search-results.png]] 53 53 54 - Thelast testingoptiondiscussed inthis fundamentalis auseracceptancetestor End-to-Endtest. In this test,not only developersortesters butalsoend-usersor otherpeoplefrom the business sideare involved.Therefore,thistestingmethod ismorefunctionally focusedthanthe previously discussedtests. A User Acceptancetestaims to let the business (users)accept thesolutioncreated. Normally,thissthe last step before pushingthesolutionto production.46 +For more information on data sink please check out the following [[Data sink>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Data Management.advanced-data-management-data-sink||target="blank"]] 55 55 56 - Allthepreviouslymentioned eMagizfunctionalityhelpsyoucompleteanEnd-to-Endtestor solveuesfound withinthetesteffectively.More informationonthistestingmethodcanbefoundin the microlearning:48 +However, in some cases, there are additional legal requirements you need to meet. These legal requirements require you to prove for an extended period (i.e., seven years) that a specific message was sent at a particular moment in time. For this requirement, we have the long-term archiving functionality in eMagiz. 57 57 58 - *[[User Acceptance Testing>>doc:Main.eMagizAcademy.Microlearnings.IntermediateLevel.Testing in eMagiz.intermediate-testing-in-emagiz-user-acceptance-testing||target="blank"]]50 +==== 3.3 Long Term Archiving ==== 59 59 52 +The long-term archiving functionality is an expansion of the data sink functionality. By adding a specific tag to the logic within the flow, the data will be placed in the data sink and placed in our long-term archiving solution. In this solution, we will keep the data for a standard period of seven years before deleting the data from the long-term archiving solution. This allows you to retrieve chunks of data from the long-term archiving via a ticket request in our support portal. As a result, we will provide you with the requested data promptly. 53 + 54 +For more information on data sink please check out the following [[Long term archiving>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Data Management.advanced-data-management-long-term-archiving||target="blank"]] 55 + 60 60 == 4. Key takeaways == 61 61 62 -* There are different testing methods with different goals 63 -* Not every testing method can be done at any stage of development 64 -* For every testing method, eMagiz has documentation and when possible features to support testing 58 +* Each eMagiz model has a standard Manage phase in which statistics are kept on your environment 59 +* With these statistics, you can determine whether messages have been received by and sent by eMagiz 60 +* This functionality does not allow you to see the content of the messages itself 61 +* On top of that, eMagiz offers Data Sink and long term Archiving as additional licensed features 62 +* Data sink is helpful for an Ops scenario to check whether a specific message is processed by eMagiz (Traceability) 63 +* Long term archiving is helpful for legal purposes as it gives you the option to prove for seven years that a specific message is sent at a specific time (Compliancy) 65 65 66 66 == 5. Suggested Additional Readings == 67 67 68 -If you are interested in this topic and want to learn more onhowtestingcanbe donewithinthe eMagiz platform, please check out our microlearnings on testingin eMagiz:67 +If you are interested in this topic and want to learn how you can control your Cloud with the help of the eMagiz platform, please check out our microlearnings offering on eMagiz Cloud Management: 69 69 70 -* [[Crash Course (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.WebHome||target="blank"]] 71 -** [[Crash Course Platform (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course Platform.WebHome||target="blank"]] 72 -*** [[Understanding Flow Testing (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-understanding-flowtesting||target="blank"]] 73 -*** [[Configuring Flow Testing (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-configuring-flow-test||target="blank"]] 74 -*** [[Create Test Message(s) (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-creating-test-messages||target="blank"]] 75 -*** [[Running A Flow Test (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-running-flow-test||target="blank"]] 76 -*** [[Edit Test Message(s) (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-editing-test-messages||target="blank"]] 77 -*** [[Deleting Test Message(s) (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-create-deleting-test-messages||target="blank"]] 78 -* [[Intermediate Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.WebHome||target="blank"]] 79 -** [[Testing In eMagiz (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Testing in eMagiz.WebHome||target="blank"]] 80 -*** [[Regression Testing (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Testing in eMagiz.intermediate-testing-in-emagiz-regression-testing.WebHome||target="blank"]] 81 -*** [[User Acceptance Testing (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Testing in eMagiz.intermediate-testing-in-emagiz-user-acceptance-testing||target="blank"]] 82 -** [[Testing API Gateway (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Testing API Gateway.WebHome||target="blank"]] 83 -*** [[Testing API Gateway (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Testing API Gateway.intermediate-testing-emagiz-api-gateway-testing-api-gateway||target="blank"]] 84 -** [[Intermediate Solution Architecture (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Solution Architecture.WebHome||target="blank"]] 85 -* [[Advanced Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.WebHome||target="blank"]] 86 -** [[Advanced Testing in eMagiz (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Testing in eMagiz.WebHome||target="blank"]] 87 -** [[Advanced Solution Architecture (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Solution Architecture.WebHome||target="blank"]] 88 -* [[Testing (Search Result)>>url:https://docs.emagiz.com/bin/view/Main/Search?highlight=true&r=1&sortOrder=desc&f_space_facet=2%2FMain.eMagiz%20Academy.Microlearnings.&sort=score&text=%22testing%22&f_type=DOCUMENT&facet=true&f_locale=en&f_locale=&f_locale=en||target="blank"]] 69 +* [[Crashcourse Messaging>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Messaging.crashcourse-messaging-interpreting-queue-statistics||target="blank"]] 70 +* [[Data sink>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Data Management.advanced-data-management-data-sink||target="blank"]] 71 +* [[Long term archiving>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Data Management.advanced-data-management-long-term-archiving||target="blank"]] 89 89 90 90 )))((({{toc/}}))){{/container}}{{/container}} 
 
