-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathChangeLog.txt
80 lines (68 loc) · 7.93 KB
/
ChangeLog.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
Goals of the Enhanced ReFramework:
Provide a clear structure to the framework, both in project folder structure as well as code wise.
Separate it in layers such that the framework layer provides an easily configurable engine for running diverse processes with local or Queue data.
Framework layer should provide a common interface to call business logic code and seamlessly provide top-level application environment recovery and transaction retry logic.
Make the business logic components easily accessible in the code.
Keep the same business logic components ("InitAllApplications.xaml", "GetSetTransactionData.xaml", "ProcessTransaction.xaml", "CloseAllApplications.xaml", "KillallProcesses.xaml"), making migration from previous version seamless.
Changelog:
* Achieve modularity and reusability by defining a new structure called a Workblock purposed to log runtime details of code running inside. Reuse structure for framework states and business code .(Note 1)
* Strive to Achieve Separation of Concerns by splitting the framework into layers. Thus, business should only be concerned with Business Logic code. (Note 2)
* State machine transitions is where the framework managed transaction iterators, the TransactionNumber and RetryNumber are incremented and system flags set. They are now kept in a dictionary called SystemReserved.
* SetTransactionStatus.xaml has now disappeared.
* CleanupAndPrep.xaml workflow added to ProcessLayer folder; This workflow gets executed once upon process startup.
* Process.xaml is moved/renamed to ProcessLayer\ProcessTransaction.xaml.
* Framework\GetTransactionData.xaml is moved/renamed ProcessLayer\GetSetTransactionData.xaml.
* Framework\InitAllApplications.xaml is moved/renamed ProcessLayer\InitAllApplications.xaml.
* Framework\CloseAllApplications.xaml is moved/renamed ProcessLayer\CloseAllApplications.xaml.
* Framework\KillAllProcesses.xaml is moved/renamed ProcessLayer\KillAllProcesses.xaml.
* ProcessLayer\CloseAllApplications.xaml called in case of recovery from System Error is now called in the InitLayer.
* Init state now retries a number of times upon exception, configurable from the Data\Config.xlsx file.
* ProcessLayer\KillAllProcesses.xaml is now called in the try catch of the ProcessLayer\CloseAllApplications.xaml file, allowing better dev control without touching the framework layer.
* When TrainsactionItem is a QueueItem, use GetQueueMaxRetries.xaml to query Orchestrator server and obtain maximum retry information. This function uses 2018.1 REST API authentication through the robot, and is not compatible to previous versions.
* State machine now remembers consecutive application exceptions that occurred in the Process Transaction State and will abort process upon reaching configurable (Data\Config.xlsx) maximum. (Ex: Use this to prevent a robot consuming items
* Implement services; Each service a Enhanced ReFramework engine in it's own right, It consists of a Main.xaml file as well as it's own ProcessLayer and Data folders. The ServiesLayer folder now stores the default services/service templates. (Note 4)
* listOfDictToDt.xaml is a new workflow that is used to convert the Audit object (the status of workblocks) from dictionary to dt and save it to disk in csv format. Component of test framework.
* Reorganize Data\Config.xlsx and provide some manner of in-file guidance. (Note 3)
* Added a Workblock Snippet folder containing a Workblock Template. Add this to the library folder and drag to create a workblock in a new Enhanced ReFramework project.
Notes:
1. Framework is now composed of Work Blocks. Each work block represents the minimal run and log structure. It is made up of a try-catch block. Within the Try section, the code we want to execute. After executing we log success, gathering runtime and hierarchical information from child Workblocks and passing it on to parent the Workblock. If an exception occurs within the code, the work block will catch the exception, log the failure, output the exception and rethrow it.
As such, the framework layer has 4 Workblocks. A master Workblock, let's call it "MainTask". This workblock has three child Workblocks: "Init", "GetSetData" and "Process".
A workblock will add default log fields both at the beginning and at the end of execution.
At the start of workblock execution, the following log fields with the following values will be added:
wbName: string = Workblock Name property or workflow name if empty
wbParentName: string = Parent Workblock Name property or parent workflow name if empty
wbKey: string = unique identifier for the instance
wbParentKey: string = unique identifier for parent instance
wbPath: string = Top down path is formed of wbNames, separated by “|”
wbLevel: int = the number of “|”
wbStartTime: string = now.ToString(“yyyyMMdd HH:mm:ss.fff”) (format discussion)
wbState: string = “Executing”
Message: string = “Workblock [wbName] execution started.”
At the end of the workblock execution, if it is successful, the following log fields will be added/changed:
wbStatus: string = “Successful”
wbState: string = “Ended”
wbDurationSec: double = duration in seconds
message: “Workblock [wbName] has finished successfully.”
If the workblock is failed, the following log fields will be added/changed:
wbStatus: string = ”Failed”
wbState: string = “Ended”
wbDurationSec: double = duration in seconds
wbExceptionType: string = exception.GetType.Name
wbExceptionMessage: string = exception.Message
Message: “Workblock [wbName] has failed with the [exception.GetType.Name]: [exception.Message].
2. Separate the different components of the framework into layers:
a) Framework layer (the main dataflow representation, a state machine, calling different components of code). In this section the pieces of code that are needed for framework operation are encapsulated in a "System Reserved" sequence.
This layer provides Transaction iterators and recovery mechanisms for Application exceptions by calling the user defined structure for reinitializing the environment.
b) Data layer (ProcessLayer\GetSetTransactionData.xaml), where working with transactional data is to take place. Clear separation between working with data and working with applications.
c) Business Process layer (the workflows that need to be modified to achieve the desired process behavior - InitAllApplications.xaml, CloseAllApplications.xaml, KillAllProcesses.xaml, ProcessTransaction.xaml)
3. Organize Config.xlsx better by creating the following extra sheets:
a) introduction sheet (write some documentation with regard to the Config)
b) credentials sheet (place credentials here)
c) Workblock sheet (name Workblocks running in the framework layer here)
d) tasks sheet (details about services layer on)
4. Implement a pluggable services/tasks layer. Services are found within the ServiceLayer folder. Each task has it's own ProcessLayer folder, with all the expected components, and it's own Data\Config.xlsx file.
A task is a standard framework that will act like a slave running within the main workflow. The framework now implements two system services, "FirstRunTask" and "GetDataTask". Both are off by default. If enabled:
a) FirstRunTask will run only once, at the start of the process. Possible use case: queue dispatcher
b) GetDataTask will either run once, on the first process run, or on every process run. Possible use case: The data needed for processing is obtained from a resource that can fail (for example, a website). You simply then configure GetDataTask to independently get your data and output it in the main task.
We include two more services examples, "Task1" and "Task2", that could be called in the ProcessLayer\ProcessTransaction.xaml file. It's useful when, within a process, we need to work with multiple independent applications. Instead of implementing everything within the process section, we simply launch a service that solves said task.
It should be noted that, even though theoretically one could have service within service implementations, we highly discourage it and consider a horizontal development tends to yield better results.