Sunday, January 7, 2018

Passed SF Lightning Component Framework Specialist

I finally passed the SF Lightning Component Framework Specialist Superbadge.  This is a nice small project to check most important lightning knowledge.

To get this super badge,  you need familiar with

  • Common Lightning components
    • <ui:scrollerWrapper>
    • <aura:iteration>
    • <lightning:formattedDateTime>
    • <lightning:card>
    • <lightning:layoutItem>
    • <lightning:layout>
    • <aura:if>
    • <lightning:tabset>, <lightning:tab>
    • <lightning:button>, <lightning:formattedDateTime>, <lightning:select>
  • Lightning Data Servcie: <force:recordData>
  • Lightning Events: application event and component event
  • Some global predefined event:
    • init
    • attribute change
    • createRecord
  • Component interface: public attribute, component method
  • Lightning design system
  • lightning Apex controller
  • some basic JS knowledge
I totally spent about 20 hours to finish this project. When implementing this project, pay attention to the component/event/method/attribute name and UI element id. I believe in verifying challenges, SF use code scan to make sure all required functions are implemented correctly. Google is a good resource. A lot of people are discussing their issues in StackExchange and sf community.  Several times, in verifying challenges, my project works well but cannot pass the challenge. The experience from others save me a lot of time.

Sunday, August 16, 2015

How to deploy field permission by Migration Tool

When creating a new custom field and deploying to Sandbox or production, system admin always need to manually change the field-level security. By using migration tool, we can do this automatically.

1. prepare meta data files
For each profile name, create a file PROFILE_AME.profile, the content should be like this:
Following file will modify the Lead.BusinessName__c field as read/write for system administrator profile users.

Admin.profile
<?xml version="1.0" encoding="UTF-8"?>
<Profile xmlns="http://soap.sforce.com/2006/04/metadata">
<custom>false</custom>
<fieldPermissions>
        <editable>true</editable>
        <field>Lead.BusinessName__c</field>
        <readable>true</readable>
</fieldPermissions>
</Profile>

<custom>false</custom>: means it is standard profile. If you do not specify this, the tool will consider it is a custom profile. 

If you want to modify system administrator and AE profiles, please create two similar files for each profiles.  Please note, system administrator profile file should be Admin.profile. Files name for Standard profiles might be a little different than its profile names.  

AE.profile
<?xml version="1.0" encoding="UTF-8"?>
<Profile xmlns="http://soap.sforce.com/2006/04/metadata">
<custom>true</custom>
<fieldPermissions>
        <editable>false</editable>
        <field>Lead.BusinessName__c</field>
        <readable>true</readable>
</fieldPermissions>
</Profile>
Put above two files in retrieveUnpackaged/profiles folder

2. Modify package file
modify unpackaged/package.xml and retrieveUnpackaged/package.xml file as following:

package.xml
<?xml version="1.0" encoding="UTF-8"?>
<Package xmlns="http://soap.sforce.com/2006/04/metadata">
    <types>
        <members>*</members>
        <name>CustomField</name>        
     </types>
     <types>
        <members>*</members>     
        <name>Profile</name>        
     </types>
    <version>31.0</version>
</Package>


3. run ant command
Open command under ant migration tool folder, type ant deployUnpackaged. The deploy process will start. You can login to the target organisation to check the status of this deployment.  Please note, when deploying this to production, the tool will run all test classes.




Saturday, June 20, 2015

Mass Delete SF picklist values

In our last release, I need to remove about 260 picklist values. If I do it manually, I need to open 420 pages and click 680 buttons. Loading a SF page is not like to open Google search home page, it is very slow. I might need half day to finish it. But if in future we need to remove thousands picklist values, it might be not a good idea to do it manually. So I spent half day in weekend to automate this. 

My idea is from this blog http://frombelvideres4thfloor.blogspot.se/2011/05/javascript-hack-to-mass-delete-custom.html. But the Javascript in this blog cannot be used in the situation if the system has some records.  If the object has records in the system, and when deleting a picklist value, SF requires user to choose which value should replace the deleted one as the page shown below:

But this blog gives me a good idea to think how to automate this process.  Following is introducing my solution.
Requirements:
Process explanation:
To delete a picklist value, we need Login in to SF, go to the field detail page, click del link and goes to replace value page and click Save. I use Selenium IDE to automate this process. But only use Selenium IDE, it is difficult to only delete the picklist values we want to delete. What's more, in field detail page,  it has several section and each section contains "Del" link as shown below. Only by using Selenium IDE, it is not easy to only click the "Del" link in active picklist values section (in below picture, it is Campaign Type Picklist values).


So I use Javascript to define accurate deleting operation. only delete the choices we want to remove. 

Following is the Selenium IDE process:

Following is the flow chart for above Selenium Test Case:


Javasccript in runScriptAndWait command element:
var links = document.getElementsByTagName("a");
/* picklist values need to be deleted */
var delArray= ["value 0", "value 1", "value 2"];
/* Pick out the Del links. */ 
var delLinks = new Array();
for (
var i = 0; i < links.length; i++) {
   
var  link = links[i];   
   
var  title = link.title;
   if (link.innerHTML == "Del") {
     for(
var  j=0; j<delArray.length; j++){
          if(title.indexOf(delArray[j]) > -1){
               delLinks[delLinks.length] = link;
               break;
          };
      }
     }
  
     if(delLinks.length > 0)
          break;
}
if(delLinks.length > 0){  
/* click the del link for the pick list value that need to be deleted*/ 
  for (
var  i = 0; i < delLinks.length; i++) {
    
var  delLink = delLinks[i];
    window.open(delLink.attributes['href'].value, "_self");
  }
}


Run this tool
  • Install Firefox Selenium IDE and Selenium flow-control 
  • Login SF in Firefox
  • open Selenium IDE, download and open the test case
  • Change the loop time in "while" command. currently, it is 20, so when this test case runs, it deletes at most 20 picklist values. 
  • download and open javascript file in a txt or notepad++, modify the 3rd line, replace the value you need to delete in delArray. After modification, replace the new js in target of runScriptAndWait of Selenium IDE test case
  • Save the test case and click run button of Selenium IDE

Others
  • This tool only deletes the pick list value, won't update any existing records with new value. 
  • if you want to run this on sandbox, change the URL in "open" command
  • We might need to restart this test case several time as Firefox is easy to crash when running this. 
  • Source code of Selenium test case and javascript can be downloaded from here.




Saturday, June 13, 2015

How to Mass Update Salesforce profiles

when coming to deploy process, I think many people feel it is a big headache for changing all kinds of accessibility of objects fields, records type, Visualforce page because most of these are needed to be done manually. If the organization is not big, it might not be a so big thing, just click several buttons repeatedly. But how about if an org has hundreds of profiles?

Currently, SF provide deploy profiles by change set. But it might a little difficult to make sure that it only updates what you want to change.  This blog will detail how to update profiles by SF Migration API tool. And you will feel very safe as it will only update what you want to change.

This blog will describe the detail steps of how to deploy record type visibility as an example.

1. Download and install Migration tool:
Please following this document to download and install this tool.  Please make sure delete example files under several folders. 

2. retrieve profile metadata
For example if you want to change several user profiles' visibility of all objects' record types. 
First modify the package.xml file in unpackaged folder like following:
package.xml
<?xml version="1.0" encoding="UTF-8"?>
<Package xmlns="http://soap.sforce.com/2006/04/metadata">
     <types>
        <members>*</members>
        <name>RecordType</name>
    </types>
    <types>
        <members>*</members>
        <name>Profile</name>
    </types>
    <version>31.0</version>
</Package>

First you could retrieve these information by using following CMD:
ant retrieveUnpackaged
After successfully finished, you should get all these meta data in retrieveUnpackaged folder (You can modify the target folder by modifying build.xml file).  In this folder, it will generate a file for every profile, like following:

The tool retrieves recordTypeVisibilities and other information of all profiles as shown blow. Each profile has a separate file to store these information. Each file will like following: 
<?xml version="1.0" encoding="UTF-8"?>
<Profile xmlns="http://soap.sforce.com/2006/04/metadata">
    <custom>true</custom>
    <loginHours>...</loginHours>
    <recordTypeVisibilities>
        <default>false</default>
        <recordType>Account.Business</recordType>
        <visible>true</visible>
    </recordTypeVisibilities>

     ...
    <userPermissions>
        <enabled>true</enabled>
        <name>EditMyDashboards</name>
    </userPermissions>
    ...
</Profile>

3. modify profile meta data file
As the second step retrieved more information than we want to change, we need to modify these files before deploy to production. Delete all other properties, only include the recordtypevisibilities elements of the record types you need to modify. For example, If deploy following file (Admin.profile) to production, it will modify the visibility of Campaign.Advocacy record type to be true for Admin profile 
<?xml version="1.0" encoding="UTF-8"?>
<Profile xmlns="http://soap.sforce.com/2006/04/metadata">
    <recordTypeVisibilities>
        <default>false</default>
        <recordType>Campaign.Advocacy</recordType>
        <visible>true</visible>
    </recordTypeVisibilities> 
</Profile>

4. Deploy the changes
use ant deployUnpackaged to deploy all those files modified in previous step.

You can use similar method to manually deploy others:
- apex page / visualforce page accessibility. sample package.xml file for this:

- Apex class
- CustomObject accessibility
- CustomField accessibility
- etc.


Following package.xml will retrieve all metadata about custom object, field, record type accessibility:
After modifying the retrieved profiles, you can deploy to production.