Quick Start with Apex Development
Complete this quick start to create, test, and debug a workflow that is created using an Apex class, and sets off an Apex trigger.
We create a custom object called Book
, and add a custom field called Price
to that custom object. We update and test the updated Price field using Apex and learn how to work with Apex code using the Salesforce Extensions.
- Log in to your sandbox or Developer org.
- Go to Setup > Object Manager > Create > Custom Object.
- Enter
Book
for the label. - Enter
Books
for the plural label. - Click Save.
- In the Custom Fields & Relationships section of the Book detail page, click New.
- Select
Number
for the data type and click Next. - Enter
Price
for the field label. - Enter
16
in the length text box. - Enter
2
in the decimal places text box, and click Next. - Click Next to accept the default values for field-level security.
- Click Save.
- In VS Code, connect to the org that you added the custom object to using the Org Picker or Command Palette.
- Run the SFDX: Refresh SObject Definitions command from the Command Palette to get code completion suggestions for your SObjects related code.
- Click the Cloud icon in the Activity Bar to open the Org Browser.
- Scroll down to Custom Object and locate the
Book_c
object. Click the retrieve icon to run SFDX: Retrieve Source from Org. - From the Command Palette run SFDX
Apex Class and create a class called MyBooks
. - Add a method called
applyDiscount
to this class.
Make this method both public and static. Because it’s a static method, you don't need to create an instance of the class to access the method. Use the name of the class followed by a dot (.) and the name of the method.
This method takes one parameter, a list of Book records, which is assigned to the variable books. The method iterates through a list of books and applies a 10% discount to the current book price.
Next, add a trigger that calls this applyDiscount
method.
An Apex trigger is a piece of code that executes before or after records of a particular type are inserted, updated, or deleted from the database. Every trigger runs with a set of context variables that provide access to the records that caused the trigger to fire.
- From the Command Palette, run SFDX: Create Apex Trigger and create a class called
MyBooksTrigger
. - Update the default template to this trigger definition:
We now have the code that is needed to update the price of all books that get inserted.
Next, let’s add a test class and add a unit test. Unit tests are an important part of writing code and are required. In addition to ensuring the quality of your code, unit tests enable you to meet the code coverage requirements for deploying or packaging Apex. To deploy Apex or package it for AppExchange, unit tests must cover at least 75% of your Apex code, and those tests must pass.
Now, add a test class with one test method. Then run the test and verify code coverage. The test method exercises and validates the code in the trigger and class. Also, it enables you to reach 100% code coverage for the trigger and class. For our example, create a test class that inserts a new book object that sets off the Apex trigger we wrote earlier.
To create the test class:
- From the Command Palette, run SFDX
Apex Class and create a class called MyBooksTestClass
. - Paste the following code in the
MyBooksTestClass.cls
file:
This test class is defined using the @isTest
annotation. We recommend that classes defined this way only contain test methods and any methods required to support those test methods. One advantage to creating a separate class for testing is that classes defined with @isTest
don’t count against your org’s limit of 6 MB of Apex code. You can also add the @isTest
annotation to individual methods. For more information, see isTest Annotation and Execution Governors and Limits.
- To run the test you wrote, you must deploy your code to your org. Right-click in the file and run SFDX: Deploy This Source to Org to deploy your code.
- To test your code, click Run All Tests in the
MyBooksTestClass
file.