Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bugfix: logging no longer fails when parent transaction ID is not found #307

Merged

Conversation

jongpie
Copy link
Owner

@jongpie jongpie commented May 4, 2022

Core Package Changes

  • Fixed LogEntryEventHandler should successfully save records in Log__c & LogEntry__c, even if the specified parent transaction ID is not found #300 by adding a new field Log__c.ParentLogTransactionId__c and updated trigger handler logic to optionally set Log__c.ParentLog__c when the parent log is found (or skips it when the parent log is not found)
    • The Log__c flexipage and page layout now use a new formula field Log__c.ParentLogLink__c to display either a link to ParentLog__c when set or the text value of ParentLogTransactionId__c
  • Updated the description of perm set LoggerLogCreator to indicate that it's currently optional, but might be needed in the future
  • Optimized LogEntryEventHandler.TAG_ASSIGNMENT_RULES by adding lazy-loading (discussed in Reducing use of SOQL in synchronous context #303) and adding a check on LogEntryTagRule__mdt.getAll().isEmpty() == true to minimize the usage of querying on LogEntryTagRule__mdt
  • Cleaned up some methods in Logger_Tests, and added TODOs for several test methods that will eventually be rewritten in a future release
  • Removed some stale @SuppressWarnings annotations in a couple of Apex classes-
  • Promoted a few buried strings within Apex classes to be constants, and a cleaned up a few other small code bits
  • Removed overload for LoggerMockDataCreator.createAggregateResult(Map<String, Object>) since the current mocking approach doesn't/can't actually set any fields on the mock AggregateResult
  • Added new text field LoggerSObjectHandler__mdt.SObjectTypeOverride__c as a way to support triggers on objects that are not supported via EntityDefinition lookups
  • Fixed Unable to Install Package in SandBox v4.7.1 #308 by adding the Schema namespace to a reference of FieldSetMember (now Schema.FieldSetMember)
  • Further fixed issues like Unable to Install Package in SandBox v4.7.1 #308 by adding empty classes with problematic names (FieldSet, FieldSetMember, SObjectField, SObjectType and Test for now) - this will cause deployment errors in the pipeline if there are any references that don't use the System/Schema namespaces

New Async Failures Additions Plugin

@jamessimone created a new plugin (implemented in #309), this plugin adds support for logging asynchronous batchable and queueable exceptions.

Batchable Error Logging

All a batch class needs to do is implement the marker Database.RaisesPlatformEvents interface and create a LoggerParameter__mdt record where the Value field matches the name of the batch class you are looking to add logging for, and the DeveloperName (the "Name" field) starts with BatchError:

// the class MUST implement Database.RaisesPlatformEvents for this to work correctly!
public class MyExampleBatchable implements Database.Batchable<SObject>, Database.RaisesPlatformEvents {
    // etc ...
}

And the CMDT record:

image

Once you've correctly configured those two things (the marker interface Database.RaisesPlatformEvents on the Apex batchable class, and the Logger Parameter CMDT record), your class will now log any uncaught exceptions that cause that batch class to fail unexpectedly.

Queueable Error Logging

If you have Apex classes that implement System.Queueable, you can add error logging with some minimal code additions:

public class MyExampleQueueable implements System.Queueable {
    public void execute (System.QueueableContext qc) {
        System.attachFinalizer(new LogFinalizer());
    }
}

If you'd like to do additional processing, you can alternatively choose to extend LogFinalizer:

public class MyCustomFinalizer extends LogFinalizer {
    protected override void innerExecute(System.FinalizerContext fc) {
        // do whatever you'd like!
        // errors will be logged automatically in addition to what you choose to do here
        // no need to call Logger.saveLog() manually on this code path
    }
}

Promoted All Plugin Packages

Previously, the package plugins had not been promoted, which prevented them from being installed directly into production. The most recent package versions for each plugin has now been promoted, allowing all plugins to now be installed into production. At the moment, there are 5 plugins available:

  • Async Logging Additions plugin (brand new, see above)
  • Big Object Archiving plugin
  • Log Retention Rules plugin
  • Logger Admin Dashboard plugin
  • Slack plugin

Note that several plugins are still considered to be in beta - the code has been tested and everything is expected to work in production, but as some plugins are relatively new, there may be some bigger changes between releases (depending on community feedback about new features & bugfixes).

Pipeline Changes

  • Added CODEOWNERS file
  • Changed build.yml so that the managed package build is a dependency for creating the unlocked package. This will add more time to the build, but it will ensure that the managed package (the more problematic package) can be created before creating the unlocked package
  • Fixed some broken images in some plugin README.md
  • Fixed some dependabot alerts by adding specific versions of some packages as dependencies in package.json & recreating package-lock.json

jongpie added 9 commits May 2, 2022 17:42
…pdated trigger handler logic to optionally set Log__c.ParentLog__c when the parent log is found/skips it when the parent log is not found

I also added CODEOWNERS file, and updated the description of perm set LoggerLogCreator to indicate that it's currently optional, but might be needed in the future
…or creating the unlocked package

This will add more time to the build, but it will ensure that the managed package (the more problematic package) can be created before creating the unlocked package
… methods that will eventually be rewritten, alphabetized some fields in LogEntryEventBuilder
…String, Object>) since the current approach doesn't actually set any fields on AggregateResult

Thanks to @jamessimone for pointing this out in my last PR. Long term, I'll change the approach used for AggregateResult
…ading (discussed in #303) and added a check on `LogEntryTagRule__mdt.getAll().isEmpty() == true` to minimize the usage of querying on LogEntryTagRule__mdt
…classes, promoted a few buried strings to be constants, and a cleaned up a few other small code bits
…s dependencies & recreating package-lock.json
@jongpie jongpie had a problem deploying to Experience Cloud Scratch Org May 4, 2022 20:19 Failure
@jongpie jongpie temporarily deployed to Base Scratch Org May 4, 2022 20:53 Inactive
@jongpie jongpie temporarily deployed to Experience Cloud Scratch Org May 4, 2022 20:53 Inactive
@jongpie jongpie temporarily deployed to Demo Org May 4, 2022 21:03 Inactive
@jongpie jongpie temporarily deployed to Demo Org May 4, 2022 21:12 Inactive
jongpie added 2 commits May 6, 2022 12:15
…ic names (FieldSet, FieldSetMember, SObjectField, SObjectType and Test for now) - this will cause deployment errors in the pipeline if there are any references that don't use the System/Schema namespaces
@jongpie jongpie force-pushed the bugfix/logging-fails-when-parent-transaction-id-is-not-found branch from f594f68 to 439d24f Compare May 6, 2022 17:40
@jongpie jongpie had a problem deploying to Experience Cloud Scratch Org May 6, 2022 17:42 Failure
@jongpie jongpie had a problem deploying to Base Scratch Org May 6, 2022 17:42 Failure
@jongpie jongpie temporarily deployed to Experience Cloud Scratch Org May 6, 2022 18:06 Inactive
@jongpie jongpie temporarily deployed to Base Scratch Org May 6, 2022 18:06 Inactive
@jongpie jongpie temporarily deployed to Demo Org May 6, 2022 18:17 Inactive
@jongpie jongpie temporarily deployed to Demo Org May 6, 2022 18:28 Inactive
@jongpie jongpie mentioned this pull request May 9, 2022
10 tasks
#309)

* Adding new plugin for BatchApexErrorEvent and default Finalizer implementation for logging failures
* Code review feedback - updated test class to make use of User metadata to avoid having to perform DML/the extra logs associated with Account, and updated example image in README to correctly describe the process for enabling unexpected batch error logging
@jamessimone jamessimone temporarily deployed to Base Scratch Org May 9, 2022 19:14 Inactive
@jamessimone jamessimone temporarily deployed to Experience Cloud Scratch Org May 9, 2022 19:14 Inactive
@jamessimone jamessimone temporarily deployed to Demo Org May 9, 2022 19:38 Inactive
@jamessimone jamessimone temporarily deployed to Demo Org May 9, 2022 19:48 Inactive
@jongpie jongpie force-pushed the bugfix/logging-fails-when-parent-transaction-id-is-not-found branch from 5214e3c to 9c3d859 Compare May 10, 2022 17:53
… the new Async Failure Additions plugin (created by @jamessimone), promoted all plugin packages, added prod installation buttons in plugin README files
@jongpie jongpie force-pushed the bugfix/logging-fails-when-parent-transaction-id-is-not-found branch from 9c3d859 to 5e646cd Compare May 10, 2022 17:55
@codecov
Copy link

codecov bot commented May 10, 2022

Codecov Report

Merging #307 (520a385) into main (3b04138) will decrease coverage by 0.00%.
The diff coverage is 100.00%.

❗ Current head 520a385 differs from pull request most recent head 5e646cd. Consider uploading reports for the commit 5e646cd to get more accurate results

@@            Coverage Diff             @@
##             main     #307      +/-   ##
==========================================
- Coverage   95.53%   95.52%   -0.01%     
==========================================
  Files          43       45       +2     
  Lines        4593     4651      +58     
  Branches       92       92              
==========================================
+ Hits         4388     4443      +55     
- Misses        202      205       +3     
  Partials        3        3              
Flag Coverage Δ
Apex 96.11% <100.00%> (-0.02%) ⬇️
LWC 91.81% <ø> (ø)

Flags with carried forward coverage won't be shown. Click here to find out more.

Impacted Files Coverage Δ
...ore/main/log-management/classes/LogBatchPurger.cls 93.93% <ø> (ø)
.../main/log-management/classes/LoggerEmailSender.cls 93.10% <ø> (ø)
...-logger/core/main/logger-engine/classes/Logger.cls 94.98% <ø> (ø)
...ore/main/logger-engine/classes/LoggerDataStore.cls 100.00% <ø> (ø)
...rchiving/plugin/classes/LogEntryArchiveBuilder.cls 100.00% <ø> (ø)
...archiving/plugin/classes/LogEntryArchivePlugin.cls 94.11% <ø> (ø)
...s/slack/plugin/slack/classes/SlackLoggerPlugin.cls 95.30% <ø> (ø)
...in/log-management/classes/LogEntryEventHandler.cls 95.52% <100.00%> (-1.61%) ⬇️
...og-management/classes/LogEntryFieldSetPicklist.cls 100.00% <100.00%> (ø)
...re/main/log-management/classes/LogEntryHandler.cls 95.58% <100.00%> (ø)
... and 11 more

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 3b04138...5e646cd. Read the comment docs.

@jongpie jongpie merged commit 7c6f49c into main May 10, 2022
@jongpie jongpie deleted the bugfix/logging-fails-when-parent-transaction-id-is-not-found branch May 10, 2022 21:11
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
3 participants