Changes for page Testing in eMagiz
                  Last modified by Erik Bakker on 2024/08/08 11:24
              
      
      From version  32.1 
    
    
              edited by Erik Bakker
        
on 2024/08/08 11:24
     on 2024/08/08 11:24
      Change comment:
              There is no comment for this version
          
         
      To version  2.1 
    
    
              edited by Bouke Reitsma
        
on 2023/07/05 10:36
     on 2023/07/05 10:36
      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 -{{container}}{{container layoutStyle="columns"}}((( 2 - In this fundamental,we willexplore the varioustestingfunctionalities available within the eMagiz portal.We will delve intodifferent typesof testing,includingunittesting,regressiontesting,performancetesting,andend-to-endtesting,anddiscusshowtestingmethodsare integrated withinthe eMagizplatform. Let'sdiveintothedetailsof eachtestingmethod and understandhowtheycanbeeffectivelyappliedtoensure thefficiencyandreliabilityofyour integrations.1 +~{~{container}}~{~{container layoutStyle="columns"}}~(~(~( 2 +This fundamental will zoom in on which traceability concepts we have incorporated within the eMagiz portal to ensure that data passes 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. 3 3 4 - Shouldyouhaveany questions,pleasegetin touchwith [[academy@emagiz.com>>mailto:academy@emagiz.com]].4 +All these concepts are used for Traceability & Compliancy business requirements... 5 5 6 - ==1.Prerequisites==6 +Should you have any questions, please get in touch with academy@emagiz.com. 7 7 8 - *BasicKnowledgeoftheeMagiz Platform8 +~== 1. Prerequisites == 9 9 10 - ==2.Keyconcepts==10 +~* An overall view of the capabilities of the eMagiz platform will be helpful 11 11 12 -* Unit Testing 13 -* Regression testing 14 -* Performance Testing 15 -* End-To-End Testing 12 +~== 2. Key concepts == 16 16 17 -== 3. Testing in eMagiz == 14 +~* eMagiz offers various options to trace messages across the platform 15 +~* The three most noteworthy options are 16 + ~* Queue Statistics 17 + ~* Data Sink 18 + ~* Long Term Archiving 18 18 19 - Herewe will investigate the testing functionality incorporated within the eMagiz portal.We will focus on differentaspects of testing that canbe executed at different moments within the development of yourintegrations. We cover four different typesof testingthat arepart 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 +~== 3. Traceability in eMagiz == 20 20 21 - ===3.1Unit testing===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. 22 22 23 - Unittesting is a common practice within software platforms.Usually, developers performunit testsduring development. It entailstesting individual integrationsorthe components within an integration, such astransformations or mappings. The unit test aims to test early within the development process to identify and fix issues early before they become more complex and costly to find and solve.24 +~=== 3.1 Queue Statistics === 24 24 25 - Within eMagiz, wehavea dedicatedunitesting functionalitycalled"flow testing." Oneofthekeybenefitsofflowtestingisthatyourintegrationdoesnothave to bedeployed.Therefore,findingscanbeeasilyimplementedduringdevelopment. eMagizsupportslivetestingofcertaincomponentstotestcommunication withxternalsystems.Moreinformationonflowtestscanbe foundinthe followingmicrolearnings: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. 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"]] 28 +~[~[image~:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz~-~-queue-statistics.png]] 34 34 35 - ===3.2RegressionTesting===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. 36 36 37 - Anothertestingmethod usedwithinsoftware developments regressiontesting. Regressiontests ensure thatexisting functionality isnot impactedby newlydevelopedfunctionality. Runningthesetestsscrucial to preventingunexpectednegativechangesforcustomers.Regressiontestscan be applied ondifferentlevels, fromindividual functionalityto thewhole platform.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"]] 38 38 39 - Themainfunctionalitywithin theMagiz platformtoperform regressiontesting on yourintegrationsiscalled"Automated flow testing." Thereisanoptiontoautomate everyflow test.Whenaflow testisautomated,itwill runlautomatedflow tests once a new versionis committed. If the test fails, you will be notifiedof the flowlevel and get an overview ofthe result on release activation.Moreinformationcan befoundinthemicrolearning: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. 40 40 41 - *[[Regression Testing>>doc:Main.eMagizAcademy.Microlearnings.IntermediateLevel.Testingin eMagiz.intermediate-testing-in-emagiz-regression-testing.WebHome||target="blank"]]36 +~=== 3.2 Data Sink === 42 42 43 - ===3.3PerformanceTesting===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. 44 44 45 - A thirdmethod for testingis theperformance test. Withina performancetest, not the content is important but the amount of loadyou test on your test subject. In the caseof integrations, it means, in general, thenumberofmessages sent overacertain integration. Normally, your productionenvironmenthandles more loadthan a test orceptance environment. With a performance test,you canstimate how muchimpactnew integration hason resources, such as CPU or memory usage of the runtimes withinyour environment. More informationon how to configurethe solutionarchitecture of your model can be found in this microlearning:40 +~[~[image~:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz~-~-data-sink-view-manage.png]] 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"]] 42 +~[~[image~:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz~-~-data-sink-search-options.png]] 49 49 50 - {{warning}} Performancetesting onhe eMagizor documentation portals **not**allowed. {{/warning}}44 +~[~[image~:Main.Images.Fundamental.WebHome@fundamental-traceability-in-emagiz~-~-data-sink-search-results.png]] 51 51 52 - ===3.4End-To-EndTesting ===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"]] 53 53 54 - Thelast testingoptiondiscussedinthisfundamentalisauseracceptanceestorEnd-to-Endtest.In this test,not only developersortesters butalsoend-usersorotherpeople fromthebusiness sidearenvolved.Therefore,thistestingmethod is more functionally focusedthanthepreviously discussedtests.A User Acceptancetestaimstoletthe business (users)acceptthe solutioncreated.Normally,this isthelaststepbeforepushingthe solutionoproduction.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. 55 55 56 - Allthepreviously mentioned eMagizfunctionality helps you completean End-to-End test orsolve issues found within the test effectively. Moreinformation on this testingmethod can be found in the microlearning:50 +~==== 3.3 Long Term Archiving ==== 57 57 58 - *[[UserAcceptanceTesting>>doc:Main.eMagizAcademy.Microlearnings.IntermediateLevel.TestingineMagiz.intermediate-testing-in-emagiz-user-acceptance-testing||target="blank"]]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. 59 59 60 - ==4. Keytakeaways ==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"]] 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 56 +~== 4. Key takeaways == 65 65 66 -== 5. Suggested Additional Readings == 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) 67 67 68 - Ifyouareinterested inthis topic and want tolearnmoreon how testing can bedone withinthe eMagiz platform, pleasecheck out our microlearnings on testing in eMagiz:65 +~== 5. Suggested Additional Readings == 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.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.Intermediate Level.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.Intermediate Level.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"]] 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: 89 89 90 -)))((({{toc/}}))){{/container}}{{/container}} 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"]] 72 + 73 +~)~)~)~(~(~(~{~{toc/}}~)~)~)~{~{/container}}~{~{/container}} 
 
