From d789cf34fa2d7e28a6e25512288027f42d1fd57f Mon Sep 17 00:00:00 2001 From: Chris Duncan Date: Tue, 16 Jul 2024 23:19:15 -0700 Subject: [PATCH] Add System.Datetime.addMinutes() --- .../addMinutes/System_Datetime_addMinutes.cls | 42 +++++++++++ .../System_Datetime_addMinutes.cls-meta.xml | 9 +++ .../System_Datetime_addMinutes_TEST.cls | 69 +++++++++++++++++++ ...stem_Datetime_addMinutes_TEST.cls-meta.xml | 9 +++ 4 files changed, 129 insertions(+) create mode 100644 src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls create mode 100644 src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls-meta.xml create mode 100644 src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls create mode 100644 src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls-meta.xml diff --git a/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls b/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls new file mode 100644 index 0000000..64336fd --- /dev/null +++ b/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls @@ -0,0 +1,42 @@ +/* + * SPDX-FileCopyrightText: 2024 Chris Duncan + * SPDX-License-Identifier: GPL-3.0-or-later + */ + +global class System_Datetime_addMinutes { + + @InvocableMethod(label='System.Datetime.addMinutes()' category='Flowpex' iconName='slds:standard:event' description='Adds the specified number of minutes to a Datetime.') + + global static List System_Datetime_addMinutes (List requests) { + List responses = new List(); + for (Request req : requests) { + Response res = new Response(); + try { + res.newDatetime = req.oldDatetime.addMinutes(req.additionalMinutes); + } catch (Exception e) { + System.debug(e); + } + responses.add(res); + } + return responses; + } + + global class Request { + @InvocableVariable(required='true' label='Old Datetime' description='Datetime to be incremented.') + global Datetime oldDatetime; + + @InvocableVariable(required='true' label='Additional Minutes' description='Number of minutes to be added to the Datetime.') + global Integer additionalMinutes; + + global Request () {} + global Request (Datetime d, Integer a) { + this.oldDatetime = d; + this.additionalMinutes = a; + } + } + + global class Response { + @InvocableVariable(label='New Datetime' description='Datetime incremented by a number of minutes.') + global Datetime newDatetime; + } +} \ 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 index 0000000..7d03d55 --- /dev/null +++ b/src/System/Datetime/addMinutes/System_Datetime_addMinutes.cls-meta.xml @@ -0,0 +1,9 @@ + + + + 61.0 + Active + \ 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 index 0000000..302b28f --- /dev/null +++ b/src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls @@ -0,0 +1,69 @@ +/* + * SPDX-FileCopyrightText: 2024 Chris Duncan + * SPDX-License-Identifier: GPL-3.0-or-later + */ + +@isTest +private class System_Datetime_addMinutes_TEST { + + @isTest + static void testNoArgs () { + List requests = new List(); + + Test.startTest(); + List responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests); + Test.stopTest(); + + Assert.areEqual(0, responses.size()); + } + + @isTest + static void testEmptyRequest () { + List requests = new List(); + System_Datetime_addMinutes.Request req = new System_Datetime_addMinutes.Request(); + requests.add(req); + + Test.startTest(); + List responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests); + Test.stopTest(); + + Assert.areEqual(1, responses.size()); + Assert.isNull(responses[0].newDatetime); + } + + @isTest + static void testBlankArgs () { + System_Datetime_addMinutes.Request req0 = new System_Datetime_addMinutes.Request(null, null); + System_Datetime_addMinutes.Request req1 = new System_Datetime_addMinutes.Request(Datetime.now(), null); + System_Datetime_addMinutes.Request req2 = new System_Datetime_addMinutes.Request(null, 1); + List requests = new List{req0, req1, req2}; + + Test.startTest(); + List responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests); + Test.stopTest(); + + Assert.areEqual(3, responses.size()); + Assert.isNull(responses[0].newDatetime); + Assert.isNull(responses[1].newDatetime); + Assert.isNull(responses[2].newDatetime); + } + + @isTest + static void testManyArgs () { + Datetime now = Datetime.now(); + + Test.startTest(); + List requests = new List(); + for (Integer i = 0; i < 3; i++) { + System_Datetime_addMinutes.Request req = new System_Datetime_addMinutes.Request(now, i); + requests.add(req); + } + List responses = System_Datetime_addMinutes.System_Datetime_addMinutes(requests); + Test.stopTest(); + + Assert.areEqual(3, responses.size()); + for (Integer i = 0; i < 3; i++) { + Assert.areEqual(now.addMinutes(i), responses[i].newDatetime); + } + } +} \ 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 index 0000000..7d03d55 --- /dev/null +++ b/src/System/Datetime/addMinutes/System_Datetime_addMinutes_TEST.cls-meta.xml @@ -0,0 +1,9 @@ + + + + 61.0 + Active + \ No newline at end of file -- 2.52.0