]> git.codecow.com Git - flowpex.git/commitdiff
Add System.Datetime.addMinutes()
authorChris Duncan <chris@flowpex.dev>
Wed, 17 Jul 2024 06:19:15 +0000 (23:19 -0700)
committerChris Duncan <chris@flowpex.dev>
Wed, 17 Jul 2024 06:19:15 +0000 (23:19 -0700)
src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls [new file with mode: 0644]
src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls-meta.xml [new file with mode: 0644]
src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls [new file with mode: 0644]
src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls-meta.xml [new file with mode: 0644]

diff --git a/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls b/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls
new file mode 100644 (file)
index 0000000..64336fd
--- /dev/null
@@ -0,0 +1,42 @@
+/*\r
+ * SPDX-FileCopyrightText: 2024 Chris Duncan <chris@flowpex.dev>\r
+ * SPDX-License-Identifier: GPL-3.0-or-later\r
+ */\r
+\r
+global class System_Datetime_addMinutes {\r
+\r
+    @InvocableMethod(label='System.Datetime.addMinutes()' category='Flowpex' iconName='slds:standard:event' description='Adds the specified number of minutes to a Datetime.')\r
+\r
+    global static List<Response> System_Datetime_addMinutes (List<Request> requests) {\r
+        List<Response> responses = new List<Response>();\r
+        for (Request req : requests) {\r
+            Response res = new Response();\r
+            try {\r
+                res.newDatetime = req.oldDatetime.addMinutes(req.additionalMinutes);\r
+            } catch (Exception e) {\r
+                System.debug(e);\r
+            }\r
+            responses.add(res);\r
+        }\r
+        return responses;\r
+    }\r
+\r
+    global class Request {\r
+        @InvocableVariable(required='true' label='Old Datetime' description='Datetime to be incremented.')\r
+        global Datetime oldDatetime;\r
+\r
+        @InvocableVariable(required='true' label='Additional Minutes' description='Number of minutes to be added to the Datetime.')\r
+        global Integer additionalMinutes;\r
+\r
+        global Request () {}\r
+        global Request (Datetime d, Integer a) {\r
+            this.oldDatetime = d;\r
+            this.additionalMinutes = a;\r
+        }\r
+    }\r
+\r
+    global class Response {\r
+        @InvocableVariable(label='New Datetime' description='Datetime incremented by a number of minutes.')\r
+        global Datetime newDatetime;\r
+    }\r
+}
\ No newline at end of file
diff --git a/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls-meta.xml b/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls-meta.xml
new file mode 100644 (file)
index 0000000..7d03d55
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version="1.0" encoding="UTF-8"?>\r
+<!--\r
+SPDX-FileCopyrightText: 2024 Chris Duncan <chris@flowpex.dev>\r
+SPDX-License-Identifier: GPL-3.0-or-later\r
+-->\r
+<ApexClass xmlns="http://soap.sforce.com/2006/04/metadata">\r
+    <apiVersion>61.0</apiVersion>\r
+    <status>Active</status>\r
+</ApexClass>
\ No newline at end of file
diff --git a/src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls b/src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls
new file mode 100644 (file)
index 0000000..302b28f
--- /dev/null
@@ -0,0 +1,69 @@
+/*\r
+ * SPDX-FileCopyrightText: 2024 Chris Duncan <chris@flowpex.dev>\r
+ * SPDX-License-Identifier: GPL-3.0-or-later\r
+ */\r
+\r
+@isTest\r
+private class System_Datetime_addMinutes_TEST {\r
+\r
+    @isTest\r
+    static void testNoArgs () {\r
+        List<System_Datetime_addMinutes.Request> requests = new List<System_Datetime_addMinutes.Request>();\r
+\r
+        Test.startTest();\r
+        List<System_Datetime_addMinutes.Response> responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests);\r
+        Test.stopTest();\r
+\r
+        Assert.areEqual(0, responses.size());\r
+    }\r
+\r
+    @isTest\r
+    static void testEmptyRequest () {\r
+        List<System_Datetime_addMinutes.Request> requests = new List<System_Datetime_addMinutes.Request>();\r
+        System_Datetime_addMinutes.Request req = new System_Datetime_addMinutes.Request();\r
+        requests.add(req);\r
+\r
+        Test.startTest();\r
+        List<System_Datetime_addMinutes.Response> responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests);\r
+        Test.stopTest();\r
+\r
+        Assert.areEqual(1, responses.size());\r
+        Assert.isNull(responses[0].newDatetime);\r
+    }\r
+\r
+    @isTest\r
+    static void testBlankArgs () {\r
+        System_Datetime_addMinutes.Request req0 = new System_Datetime_addMinutes.Request(null, null);\r
+        System_Datetime_addMinutes.Request req1 = new System_Datetime_addMinutes.Request(Datetime.now(), null);\r
+        System_Datetime_addMinutes.Request req2 = new System_Datetime_addMinutes.Request(null, 1);\r
+        List<System_Datetime_addMinutes.Request> requests = new List<System_Datetime_addMinutes.Request>{req0, req1, req2};\r
+\r
+        Test.startTest();\r
+        List<System_Datetime_addMinutes.Response> responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests);\r
+        Test.stopTest();\r
+\r
+        Assert.areEqual(3, responses.size());\r
+        Assert.isNull(responses[0].newDatetime);\r
+        Assert.isNull(responses[1].newDatetime);\r
+        Assert.isNull(responses[2].newDatetime);\r
+    }\r
+\r
+    @isTest\r
+    static void testManyArgs () {\r
+        Datetime now = Datetime.now();\r
+\r
+        Test.startTest();\r
+        List<System_Datetime_addMinutes.Request> requests = new List<System_Datetime_addMinutes.Request>();\r
+        for (Integer i = 0; i < 3; i++) {\r
+            System_Datetime_addMinutes.Request req = new System_Datetime_addMinutes.Request(now, i);\r
+            requests.add(req);\r
+        }\r
+        List<System_Datetime_addMinutes.Response> responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests);\r
+        Test.stopTest();\r
+\r
+        Assert.areEqual(3, responses.size());\r
+        for (Integer i = 0; i < 3; i++) {\r
+            Assert.areEqual(now.addMinutes(i), responses[i].newDatetime);\r
+        }\r
+    }\r
+}
\ No newline at end of file
diff --git a/src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls-meta.xml b/src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls-meta.xml
new file mode 100644 (file)
index 0000000..7d03d55
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version="1.0" encoding="UTF-8"?>\r
+<!--\r
+SPDX-FileCopyrightText: 2024 Chris Duncan <chris@flowpex.dev>\r
+SPDX-License-Identifier: GPL-3.0-or-later\r
+-->\r
+<ApexClass xmlns="http://soap.sforce.com/2006/04/metadata">\r
+    <apiVersion>61.0</apiVersion>\r
+    <status>Active</status>\r
+</ApexClass>
\ No newline at end of file