--- policy: /ce/ca/aws/cloudtrail/trail-cloudwatch-logs-integration logic: /ce/ca/aws/cloudtrail/trail-cloudwatch-logs-integration/prod.logic.yaml executionTime: 2026-04-25T12:02:18.220448065Z generationMs: 148 executionMs: 1963 rows: - id: test1 match: true status: expected: DISAPPEARED actual: DISAPPEARED conditionIndex: expected: 99 actual: 99 conditionText: expected: isDisappeared(CA10__disappearanceTime__c) actual: isDisappeared(CA10__disappearanceTime__c) runtimeError: {} - id: test2 match: true status: expected: INCOMPLIANT actual: INCOMPLIANT conditionIndex: expected: 199 actual: 199 conditionText: expected: CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty() actual: CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty() runtimeError: {} - id: test3 match: true status: expected: INCOMPLIANT actual: INCOMPLIANT conditionIndex: expected: 199 actual: 199 conditionText: expected: CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty() actual: CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty() runtimeError: {} - id: test4 match: true status: expected: INCOMPLIANT actual: INCOMPLIANT conditionIndex: expected: 299 actual: 299 conditionText: expected: isEmptyLookup('CA10__cloudWatchLogsLogGroup__r') actual: isEmptyLookup('CA10__cloudWatchLogsLogGroup__r') runtimeError: {} - id: test5 match: true status: expected: INCOMPLIANT actual: INCOMPLIANT conditionIndex: expected: 399 actual: 399 conditionText: expected: isEmptyLookup('CA10__cloudWatchLogsRole__r') actual: isEmptyLookup('CA10__cloudWatchLogsRole__r') runtimeError: {} - id: test6 match: true status: expected: COMPLIANT actual: COMPLIANT conditionIndex: expected: 499 actual: 499 conditionText: expected: notEmptyLookup('CA10__cloudWatchLogsLogGroup__r') && notEmptyLookup('CA10__cloudWatchLogsRole__r') actual: notEmptyLookup('CA10__cloudWatchLogsLogGroup__r') && notEmptyLookup('CA10__cloudWatchLogsRole__r') runtimeError: {} usedFiles: - path: /ce/ca/aws/cloudtrail/trail-cloudwatch-logs-integration/policy.yaml md5Hash: 16504C33C016D11A1231498479E81588 content: | --- names: full: "AWS CloudTrail Trail is not integrated with CloudWatch Logs" contextual: "Trail is not integrated with CloudWatch Logs" description: > Ensure that AWS CloudTrail trails are integrated with Amazon CloudWatch Logs to support centralized, near-real-time monitoring, alerting, and investigation of trail activity. type: "COMPLIANCE_POLICY" categories: - "SECURITY" - "RELIABILITY" frameworkMappings: - "/frameworks/cloudaware/logging-and-monitoring/logging-and-monitoring-configuration" - "/frameworks/aws-fsbp-v1.0.0/cloudtrail/05" similarPolicies: awsSecurityHub: - name: "[CloudTrail.5] CloudTrail trails should be integrated with Amazon CloudWatch Logs" url: "https://docs.aws.amazon.com/securityhub/latest/userguide/cloudtrail-controls.html#cloudtrail-5" - path: /ce/ca/aws/cloudtrail/trail-cloudwatch-logs-integration/prod.logic.yaml md5Hash: 9CDE2FB9DF0EEF3BFF88F947D494F663 content: | --- inputType: "CA10__CaAwsCloudTrailTrail__c" testData: - file: "test-data.json" conditions: - status: "INCOMPLIANT" currentStateMessage: "CloudTrail integration with CloudWatch Logs is not configured." remediationMessage: "Configure the trail to deliver events to a CloudWatch Logs log group by using an IAM role for CloudWatch Logs delivery." check: OR: args: - IS_EMPTY: arg: FIELD: path: "CA10__cloudWatchLogsLogGroupArn__c" - IS_EMPTY: arg: FIELD: path: "CA10__cloudWatchLogsRoleArn__c" - status: "INCOMPLIANT" currentStateMessage: "The configured CloudWatch Logs log group is missing." remediationMessage: "Verify that the trail references an active CloudWatch Logs log group." check: IS_EMPTY_LOOKUP: "CA10__cloudWatchLogsLogGroup__r" - status: "INCOMPLIANT" currentStateMessage: "The configured IAM role for CloudWatch Logs delivery is missing." remediationMessage: "Verify that the trail references an active IAM role for CloudWatch Logs delivery." check: IS_EMPTY_LOOKUP: "CA10__cloudWatchLogsRole__r" - status: "COMPLIANT" currentStateMessage: "CloudTrail is integrated with CloudWatch Logs." check: AND: args: - NOT_EMPTY_LOOKUP: "CA10__cloudWatchLogsLogGroup__r" - NOT_EMPTY_LOOKUP: "CA10__cloudWatchLogsRole__r" otherwise: status: "UNDETERMINED" currentStateMessage: "Unexpected values in the fields." - path: /ce/ca/aws/cloudtrail/trail-cloudwatch-logs-integration/test-data.json md5Hash: 3A0B303A4828CA4E7016C9F367894215 content: | [ { "expectedResult": { "status": "DISAPPEARED", "conditionIndex": "99", "conditionText": "isDisappeared(CA10__disappearanceTime__c)", "runtimeError": null }, "context": { "snapshotTime": "2026-01-15T10:42:39Z" }, "Id": "test1", "CA10__disappearanceTime__c": "2026-01-10T10:42:39Z", "CA10__cloudWatchLogsLogGroupArn__c": "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c": "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c": "test1_lg", "CA10__cloudWatchLogsLogGroup__r": { "Id": "test1_lg", "CA10__disappearanceTime__c": null }, "CA10__cloudWatchLogsRole__c": "test1_role", "CA10__cloudWatchLogsRole__r": { "Id": "test1_role", "CA10__disappearanceTime__c": null } }, { "expectedResult": { "status": "INCOMPLIANT", "conditionIndex": "199", "conditionText": "CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty()", "runtimeError": null }, "context": { "snapshotTime": "2026-01-15T10:42:39Z" }, "Id": "test2", "CA10__disappearanceTime__c": null, "CA10__cloudWatchLogsLogGroupArn__c": "", "CA10__cloudWatchLogsRoleArn__c": "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c": "", "CA10__cloudWatchLogsLogGroup__r": { "Id": null, "CA10__disappearanceTime__c": null }, "CA10__cloudWatchLogsRole__c": "test2_role", "CA10__cloudWatchLogsRole__r": { "Id": "test2_role", "CA10__disappearanceTime__c": null } }, { "expectedResult": { "status": "INCOMPLIANT", "conditionIndex": "199", "conditionText": "CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty()", "runtimeError": null }, "context": { "snapshotTime": "2026-01-15T10:42:39Z" }, "Id": "test3", "CA10__disappearanceTime__c": null, "CA10__cloudWatchLogsLogGroupArn__c": "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c": "", "CA10__cloudWatchLogsLogGroup__c": "test3_lg", "CA10__cloudWatchLogsLogGroup__r": { "Id": "test3_lg", "CA10__disappearanceTime__c": null }, "CA10__cloudWatchLogsRole__c": "", "CA10__cloudWatchLogsRole__r": { "Id": null, "CA10__disappearanceTime__c": null } }, { "expectedResult": { "status": "INCOMPLIANT", "conditionIndex": "299", "conditionText": "isEmptyLookup('CA10__cloudWatchLogsLogGroup__r')", "runtimeError": null }, "context": { "snapshotTime": "2026-01-15T10:42:39Z" }, "Id": "test4", "CA10__disappearanceTime__c": null, "CA10__cloudWatchLogsLogGroupArn__c": "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c": "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c": "test4_lg", "CA10__cloudWatchLogsLogGroup__r": { "Id": "test4_lg", "CA10__disappearanceTime__c": "2026-01-10T10:42:39Z" }, "CA10__cloudWatchLogsRole__c": "test4_role", "CA10__cloudWatchLogsRole__r": { "Id": "test4_role", "CA10__disappearanceTime__c": null } }, { "expectedResult": { "status": "INCOMPLIANT", "conditionIndex": "399", "conditionText": "isEmptyLookup('CA10__cloudWatchLogsRole__r')", "runtimeError": null }, "context": { "snapshotTime": "2026-01-15T10:42:39Z" }, "Id": "test5", "CA10__disappearanceTime__c": null, "CA10__cloudWatchLogsLogGroupArn__c": "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c": "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c": "test5_lg", "CA10__cloudWatchLogsLogGroup__r": { "Id": "test5_lg", "CA10__disappearanceTime__c": null }, "CA10__cloudWatchLogsRole__c": "test5_role", "CA10__cloudWatchLogsRole__r": { "Id": "test5_role", "CA10__disappearanceTime__c": "2026-01-10T10:42:39Z" } }, { "expectedResult": { "status": "COMPLIANT", "conditionIndex": "499", "conditionText": "notEmptyLookup('CA10__cloudWatchLogsLogGroup__r') && notEmptyLookup('CA10__cloudWatchLogsRole__r')", "runtimeError": null }, "context": { "snapshotTime": "2026-01-15T10:42:39Z" }, "Id": "test6", "CA10__disappearanceTime__c": null, "CA10__cloudWatchLogsLogGroupArn__c": "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c": "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c": "test6_lg", "CA10__cloudWatchLogsLogGroup__r": { "Id": "test6_lg", "CA10__disappearanceTime__c": null }, "CA10__cloudWatchLogsRole__c": "test6_role", "CA10__cloudWatchLogsRole__r": { "Id": "test6_role", "CA10__disappearanceTime__c": null } } ] script: |- CREATE TEMP FUNCTION mock_ExpectedResult() RETURNS ARRAY >> DETERMINISTIC LANGUAGE js AS r""" return [ { "Id" : "test1", "expectedResult" : { "status" : "DISAPPEARED", "conditionIndex" : "99", "conditionText" : "isDisappeared(CA10__disappearanceTime__c)", "runtimeError" : null } }, { "Id" : "test2", "expectedResult" : { "status" : "INCOMPLIANT", "conditionIndex" : "199", "conditionText" : "CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty()", "runtimeError" : null } }, { "Id" : "test3", "expectedResult" : { "status" : "INCOMPLIANT", "conditionIndex" : "199", "conditionText" : "CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty()", "runtimeError" : null } }, { "Id" : "test4", "expectedResult" : { "status" : "INCOMPLIANT", "conditionIndex" : "299", "conditionText" : "isEmptyLookup('CA10__cloudWatchLogsLogGroup__r')", "runtimeError" : null } }, { "Id" : "test5", "expectedResult" : { "status" : "INCOMPLIANT", "conditionIndex" : "399", "conditionText" : "isEmptyLookup('CA10__cloudWatchLogsRole__r')", "runtimeError" : null } }, { "Id" : "test6", "expectedResult" : { "status" : "COMPLIANT", "conditionIndex" : "499", "conditionText" : "notEmptyLookup('CA10__cloudWatchLogsLogGroup__r') && notEmptyLookup('CA10__cloudWatchLogsRole__r')", "runtimeError" : null } } ]; """; CREATE TEMP FUNCTION mock_CA10__CaAwsCloudTrailTrail__c() RETURNS ARRAY >> DETERMINISTIC LANGUAGE js AS r""" return [ { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "CA10__disappearanceTime__c" : new Date("2026-01-10T10:42:39Z"), "CA10__cloudWatchLogsLogGroupArn__c" : "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c" : "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c" : "test1_lg", "CA10__cloudWatchLogsRole__c" : "test1_role", "Id" : "test1" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "CA10__cloudWatchLogsLogGroupArn__c" : "", "CA10__cloudWatchLogsRoleArn__c" : "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c" : "", "CA10__cloudWatchLogsRole__c" : "test2_role", "Id" : "test2" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "CA10__cloudWatchLogsLogGroupArn__c" : "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c" : "", "CA10__cloudWatchLogsLogGroup__c" : "test3_lg", "CA10__cloudWatchLogsRole__c" : "", "Id" : "test3" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "CA10__cloudWatchLogsLogGroupArn__c" : "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c" : "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c" : "test4_lg", "CA10__cloudWatchLogsRole__c" : "test4_role", "Id" : "test4" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "CA10__cloudWatchLogsLogGroupArn__c" : "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c" : "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c" : "test5_lg", "CA10__cloudWatchLogsRole__c" : "test5_role", "Id" : "test5" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "CA10__cloudWatchLogsLogGroupArn__c" : "arn:aws:logs:us-east-1:123456789012:log-group:trail", "CA10__cloudWatchLogsRoleArn__c" : "arn:aws:iam::123456789012:role/CloudTrailLogsRole", "CA10__cloudWatchLogsLogGroup__c" : "test6_lg", "CA10__cloudWatchLogsRole__c" : "test6_role", "Id" : "test6" } ]; """; CREATE TEMP FUNCTION mock_CA10__CaAwsCloudWatchLogsLogGroup__c() RETURNS ARRAY >> DETERMINISTIC LANGUAGE js AS r""" return [ { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test1_lg" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : null }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test3_lg" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test4_lg", "CA10__disappearanceTime__c" : new Date("2026-01-10T10:42:39Z") }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test5_lg" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test6_lg" } ]; """; CREATE TEMP FUNCTION mock_CA10__CaAwsRole__c() RETURNS ARRAY >> DETERMINISTIC LANGUAGE js AS r""" return [ { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test1_role" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test2_role" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : null }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test4_role" }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test5_role", "CA10__disappearanceTime__c" : new Date("2026-01-10T10:42:39Z") }, { "context" : { "snapshotTime" : new Date("2026-01-15T10:42:39Z") }, "Id" : "test6_role" } ]; """; CREATE TEMP FUNCTION process_CA10__CaAwsCloudTrailTrail__c( obj STRUCT< CA10__disappearanceTime__c TIMESTAMP, CA10__cloudWatchLogsLogGroupArn__c STRING, CA10__cloudWatchLogsRoleArn__c STRING, CA10__cloudWatchLogsLogGroup__c STRING, CA10__cloudWatchLogsRole__c STRING, Id STRING, CA10__cloudWatchLogsLogGroup__r STRUCT< Id STRING, CA10__disappearanceTime__c TIMESTAMP >, CA10__cloudWatchLogsRole__r STRUCT< Id STRING, CA10__disappearanceTime__c TIMESTAMP > >, snapshotTime TIMESTAMP ) RETURNS STRUCT DETERMINISTIC LANGUAGE js AS r""" var TextLib = new function () { this.normalize = function(arg) { return arg == null ? '' : arg.replace(/\s+/g, ' ').trim().toLowerCase(); }; this.isEmpty = function(arg) { return this.normalize(arg) == ''; }; this.isNotEmpty = function(arg) { return this.normalize(arg) != ''; }; this.equal = function(left, right) { return this.normalize(left) == this.normalize(right); }; this.notEqual = function(left, right) { return this.normalize(left) != this.normalize(right); }; this.startsWith = function(arg, substring) { return this.normalize(arg).startsWith(this.normalize(substring)); }; this.endsWith = function(arg, substring) { return this.normalize(arg).endsWith(this.normalize(substring)); }; this.contains = function(arg, substring) { return this.normalize(arg).includes(this.normalize(substring)); }; this.containsAll = function(arg, substrings) { if (substrings == null || substrings.length === 0) return false; let normalizedArg = this.normalize(arg); return substrings.every(sub => normalizedArg.includes(this.normalize(sub))); }; this.containsAny = function(arg, substrings) { if (substrings == null || substrings.length === 0) return false; let normalizedArg = this.normalize(arg); return substrings.some(sub => normalizedArg.includes(this.normalize(sub))); }; }(); var references1 = []; // condition[0], conditionIndex:[0..99] references1.push('Deleted From AWS [CA10__disappearanceTime__c]: ' + obj.CA10__disappearanceTime__c); if (obj.CA10__disappearanceTime__c != null) { return {status: 'DISAPPEARED', conditionIndex: 99, conditionText: "isDisappeared(CA10__disappearanceTime__c)", currentStateMessage: "Object is deleted in the source", currentStateReferences: references1.join('\n'), remediation: null, runtimeError: null}; } // condition[1], conditionIndex:[100..199] references1.push('CloudWatch Logs Log Group ARN [obj.CA10__cloudWatchLogsLogGroupArn__c]: ' + obj.CA10__cloudWatchLogsLogGroupArn__c); references1.push('CloudWatch Logs Role ARN [obj.CA10__cloudWatchLogsRoleArn__c]: ' + obj.CA10__cloudWatchLogsRoleArn__c); if (TextLib.isEmpty(obj.CA10__cloudWatchLogsLogGroupArn__c) || TextLib.isEmpty(obj.CA10__cloudWatchLogsRoleArn__c)) { return {status: 'INCOMPLIANT', conditionIndex: 199, conditionText: "CA10__cloudWatchLogsLogGroupArn__c.isEmpty() || CA10__cloudWatchLogsRoleArn__c.isEmpty()", currentStateMessage: "CloudTrail integration with CloudWatch Logs is not configured.", currentStateReferences: references1.join('\n'), remediation: "Configure the trail to deliver events to a CloudWatch Logs log group by using an IAM role for CloudWatch Logs delivery.", runtimeError: null}; } // condition[2], conditionIndex:[200..299] if (TextLib.isEmpty(obj.CA10__cloudWatchLogsLogGroupArn__c) || TextLib.isEmpty(obj.CA10__cloudWatchLogsLogGroup__c) || obj.CA10__cloudWatchLogsLogGroup__r.CA10__disappearanceTime__c != null) { return {status: 'INCOMPLIANT', conditionIndex: 299, conditionText: "isEmptyLookup('CA10__cloudWatchLogsLogGroup__r')", currentStateMessage: "The configured CloudWatch Logs log group is missing.", currentStateReferences: references1.join('\n'), remediation: "Verify that the trail references an active CloudWatch Logs log group.", runtimeError: null}; } // condition[3], conditionIndex:[300..399] if (TextLib.isEmpty(obj.CA10__cloudWatchLogsRoleArn__c) || TextLib.isEmpty(obj.CA10__cloudWatchLogsRole__c) || obj.CA10__cloudWatchLogsRole__r.CA10__disappearanceTime__c != null) { return {status: 'INCOMPLIANT', conditionIndex: 399, conditionText: "isEmptyLookup('CA10__cloudWatchLogsRole__r')", currentStateMessage: "The configured IAM role for CloudWatch Logs delivery is missing.", currentStateReferences: references1.join('\n'), remediation: "Verify that the trail references an active IAM role for CloudWatch Logs delivery.", runtimeError: null}; } // condition[4], conditionIndex:[400..499] if ((TextLib.isNotEmpty(obj.CA10__cloudWatchLogsLogGroupArn__c) && TextLib.isNotEmpty(obj.CA10__cloudWatchLogsLogGroup__c) && obj.CA10__cloudWatchLogsLogGroup__r.CA10__disappearanceTime__c == null) && (TextLib.isNotEmpty(obj.CA10__cloudWatchLogsRoleArn__c) && TextLib.isNotEmpty(obj.CA10__cloudWatchLogsRole__c) && obj.CA10__cloudWatchLogsRole__r.CA10__disappearanceTime__c == null)) { return {status: 'COMPLIANT', conditionIndex: 499, conditionText: "notEmptyLookup('CA10__cloudWatchLogsLogGroup__r') && notEmptyLookup('CA10__cloudWatchLogsRole__r')", currentStateMessage: "CloudTrail is integrated with CloudWatch Logs.", currentStateReferences: references1.join('\n'), remediation: null, runtimeError: null}; } return {status: 'UNDETERMINED', conditionIndex: 500, conditionText: "otherwise", currentStateMessage: "Unexpected values in the fields.", currentStateReferences: references1.join('\n'), remediation: null, runtimeError: null}; """; SELECT expectedResult.Id as Id, IF ( IFNULL(expectedResult.expectedResult.status, '') = IFNULL(sObject.result.status, '') AND IFNULL(expectedResult.expectedResult.conditionIndex, -1) = IFNULL(sObject.result.conditionIndex, -1) AND IFNULL(expectedResult.expectedResult.conditionText, '') = IFNULL(sObject.result.conditionText, '') AND IFNULL(expectedResult.expectedResult.runtimeError, '') = IFNULL(sObject.result.runtimeError, ''), "MATCH", "FAIL" ) as match, expectedResult.expectedResult.status as expectedStatus, sObject.result.status as actualStatus, expectedResult.expectedResult.conditionIndex as expectedConditionIndex, sObject.result.conditionIndex as actualConditionIndex, expectedResult.expectedResult.conditionText as expectedConditionText, sObject.result.conditionText as actualConditionText, expectedResult.expectedResult.runtimeError as expectedRuntimeError, sObject.result.runtimeError as actualRuntimeError FROM UNNEST(mock_ExpectedResult()) expectedResult LEFT JOIN ( SELECT sObject.CA10__disappearanceTime__c AS CA10__disappearanceTime__c, sObject.CA10__cloudWatchLogsLogGroupArn__c AS CA10__cloudWatchLogsLogGroupArn__c, sObject.CA10__cloudWatchLogsRoleArn__c AS CA10__cloudWatchLogsRoleArn__c, sObject.CA10__cloudWatchLogsLogGroup__c AS CA10__cloudWatchLogsLogGroup__c, sObject.CA10__cloudWatchLogsRole__c AS CA10__cloudWatchLogsRole__c, sObject.Id AS Id, STRUCT ( `CA10__cloudWatchLogsLogGroup__r`.Id AS Id, `CA10__cloudWatchLogsLogGroup__r`.CA10__disappearanceTime__c AS CA10__disappearanceTime__c ) AS CA10__cloudWatchLogsLogGroup__r, STRUCT ( `CA10__cloudWatchLogsRole__r`.Id AS Id, `CA10__cloudWatchLogsRole__r`.CA10__disappearanceTime__c AS CA10__disappearanceTime__c ) AS CA10__cloudWatchLogsRole__r, process_CA10__CaAwsCloudTrailTrail__c( STRUCT( sObject.CA10__disappearanceTime__c AS CA10__disappearanceTime__c, sObject.CA10__cloudWatchLogsLogGroupArn__c AS CA10__cloudWatchLogsLogGroupArn__c, sObject.CA10__cloudWatchLogsRoleArn__c AS CA10__cloudWatchLogsRoleArn__c, sObject.CA10__cloudWatchLogsLogGroup__c AS CA10__cloudWatchLogsLogGroup__c, sObject.CA10__cloudWatchLogsRole__c AS CA10__cloudWatchLogsRole__c, sObject.Id AS Id, STRUCT ( `CA10__cloudWatchLogsLogGroup__r`.Id AS Id, `CA10__cloudWatchLogsLogGroup__r`.CA10__disappearanceTime__c AS CA10__disappearanceTime__c ) AS CA10__cloudWatchLogsLogGroup__r, STRUCT ( `CA10__cloudWatchLogsRole__r`.Id AS Id, `CA10__cloudWatchLogsRole__r`.CA10__disappearanceTime__c AS CA10__disappearanceTime__c ) AS CA10__cloudWatchLogsRole__r ), sObject.context.snapshotTime ) as result FROM UNNEST(mock_CA10__CaAwsCloudTrailTrail__c()) AS sObject LEFT JOIN UNNEST(mock_CA10__CaAwsCloudWatchLogsLogGroup__c()) AS `CA10__cloudWatchLogsLogGroup__r` ON sObject.CA10__cloudWatchLogsLogGroup__c = `CA10__cloudWatchLogsLogGroup__r`.Id LEFT JOIN UNNEST(mock_CA10__CaAwsRole__c()) AS `CA10__cloudWatchLogsRole__r` ON sObject.CA10__cloudWatchLogsRole__c = `CA10__cloudWatchLogsRole__r`.Id ) sObject ON sObject.Id = expectedResult.Id;