From 5d7c0953a8124aa9320cd14cabe62a481fe396c2 Mon Sep 17 00:00:00 2001 From: Chris Duncan Date: Sat, 20 Jul 2024 23:39:00 -0700 Subject: [PATCH] Add System.Datetime.millisecond() --- .../System_Datetime_millisecond.cls | 38 +++++++++++ .../System_Datetime_millisecond.cls-meta.xml | 9 +++ .../System_Datetime_millisecond_TEST.cls | 66 +++++++++++++++++++ ...tem_Datetime_millisecond_TEST.cls-meta.xml | 9 +++ 4 files changed, 122 insertions(+) create mode 100644 src/System/Datetime/millisecond/System_Datetime_millisecond.cls create mode 100644 src/System/Datetime/millisecond/System_Datetime_millisecond.cls-meta.xml create mode 100644 src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls create mode 100644 src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls-meta.xml diff --git a/src/System/Datetime/millisecond/System_Datetime_millisecond.cls b/src/System/Datetime/millisecond/System_Datetime_millisecond.cls new file mode 100644 index 0000000..07f01a5 --- /dev/null +++ b/src/System/Datetime/millisecond/System_Datetime_millisecond.cls @@ -0,0 +1,38 @@ +/* + * SPDX-FileCopyrightText: 2024 Chris Duncan + * SPDX-License-Identifier: GPL-3.0-or-later + */ + +global class System_Datetime_millisecond { + + @InvocableMethod(label='System.Datetime.millisecond()' category='Flowpex' iconName='slds:standard:topic2' description='Return the millisecond component of a Datetime in the local time zone of the context user.') + + global static List System_Datetime_millisecond (List requests) { + List responses = new List(); + for (Request req : requests) { + Response res = new Response(); + try { + res.millisecond = req.aDatetime.millisecond(); + } catch (Exception e) { + System.debug(e); + } + responses.add(res); + } + return responses; + } + + global class Request { + @InvocableVariable(required='true' label='Datetime' description='Datetime with the desired millisecond component.') + global Datetime aDatetime; + + global Request () {} + global Request (Datetime d) { + this.aDatetime = d; + } + } + + global class Response { + @InvocableVariable(label='Millisecond' description='Millisecond component of the datetime in the local time zone of the context user.') + global Integer millisecond; + } +} \ No newline at end of file diff --git a/src/System/Datetime/millisecond/System_Datetime_millisecond.cls-meta.xml b/src/System/Datetime/millisecond/System_Datetime_millisecond.cls-meta.xml new file mode 100644 index 0000000..7d03d55 --- /dev/null +++ b/src/System/Datetime/millisecond/System_Datetime_millisecond.cls-meta.xml @@ -0,0 +1,9 @@ + + + + 61.0 + Active + \ No newline at end of file diff --git a/src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls b/src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls new file mode 100644 index 0000000..b9f0c7c --- /dev/null +++ b/src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls @@ -0,0 +1,66 @@ +/* + * SPDX-FileCopyrightText: 2024 Chris Duncan + * SPDX-License-Identifier: GPL-3.0-or-later + */ + +@isTest +private class System_Datetime_millisecond_TEST { + + @isTest + static void testNoArgs () { + List requests = new List(); + + Test.startTest(); + List responses = System_Datetime_millisecond.System_Datetime_millisecond(requests); + Test.stopTest(); + + Assert.areEqual(0, responses.size()); + } + + @isTest + static void testEmptyRequest () { + List requests = new List(); + System_Datetime_millisecond.Request req = new System_Datetime_millisecond.Request(); + requests.add(req); + + Test.startTest(); + List responses = System_Datetime_millisecond.System_Datetime_millisecond(requests); + Test.stopTest(); + + Assert.areEqual(1, responses.size()); + Assert.isNull(responses[0].millisecond); + } + + @isTest + static void testBlankArgs () { + List requests = new List(); + System_Datetime_millisecond.Request req = new System_Datetime_millisecond.Request(null); + requests.add(req); + + Test.startTest(); + List responses = System_Datetime_millisecond.System_Datetime_millisecond(requests); + Test.stopTest(); + + Assert.areEqual(1, responses.size()); + Assert.isNull(responses[0].millisecond); + } + + @isTest + static void testManyArgs () { + List requests = new List(); + for (Integer i = 0; i < 200; i++) { + Datetime dt = Datetime.newInstance(i); + System_Datetime_millisecond.Request req = new System_Datetime_millisecond.Request(dt); + requests.add(req); + } + + Test.startTest(); + List responses = System_Datetime_millisecond.System_Datetime_millisecond(requests); + Test.stopTest(); + + Assert.areEqual(200, responses.size()); + for (Integer i = 0; i < 200; i++) { + Assert.areEqual(i, responses[i].millisecond); + } + } +} \ No newline at end of file diff --git a/src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls-meta.xml b/src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls-meta.xml new file mode 100644 index 0000000..7d03d55 --- /dev/null +++ b/src/System/Datetime/millisecond/System_Datetime_millisecond_TEST.cls-meta.xml @@ -0,0 +1,9 @@ + + + + 61.0 + Active + \ No newline at end of file -- 2.52.0