Thursday, 18 July 2013

Sunitha data :

1. Security Permissions  
2. Interview Questions  
3. AOD Files and Model Information
4. List of Classes  for different Process
5. List of Best Practices
6.Contents of TDD.

==============================================================
Security Permissions in AX 2012
We can simply remember this like RDP (Role > Duty > Privileges)
Below steps will provide the permissions for the whole Form/Report
1)      Create one Role [ AOT > Security > Roles (or) System Administration > Setup > Security > Security roles]

2)      Create one duty and add that duty to the Role.

3)      Create one Privileges and add that to the Duty.


4)      In the privileges entry point added menu item
Set the Access Level property for the Menu item in the Privileges entry point node.
5)      Assign created role to the user [ System Administration > Common > Users ]

Permission for a particular field in the Form/Report

1)      Go to Form > Permissions > Read/Update/delete/Create


It will automatically works for the particular assigned role based user because this ‘Form1’ is already added in the privileges entry point node and added role. 
==========================================================



1) Difference between conpeek and confind
Confind :- we can find the position of an item.
static void conFindExample(Args _args)
{
    container c = ["item1", "item2", "item3"];
    int i;
    int j;
    ;
 
    i = conFind(c, "item2");
    j = conFind(c, "item4");
    print "Position of 'item2' in container is " + int2Str(i);
    print "Position of 'item4' in container is " + int2Str(j);
    pause;
}

Conpeek:- we can get the item in a particular position
static void conPeekExample(Args _arg)
{
    container c;
    int i;
    ;

    c = conIns(["item1", "item2"], 1); 
    for (i = 1 ; i <= conLen(c) ; i++) 
    {
        print conPeek(c, i);
    }
    pause;
}

 2)  Method overloading and Method overriding
X++ supports overriding, but it does not support overloading.

Overriding a Method [AX 2012]
The methods in a class are inherited by any class that extends it. You can alter the functionality of an inherited method by creating a method in the subclass with the same name and parameters as in the superclass. This is called overriding the method. For example:
// Superclass: Attribute
public class Attribute
{
    int objectVariable;
}
void methodAtt()
{
    //Some statements
}
// Subclass: ColorAttribute
public class ColorAttribute extends Attribute
{
    int addedObjectVariable;
}
void methodAtt()
{
    //Some statements
}
ColorAttribute is a subclass of Attribute and therefore inherits the method methodAttr. However, because ColorAttribute defines a method with the same name and the same number of arguments, the method in the superclass is overridden.

Static methods cannot be overridden because they exist per class. To protect other sensitive methods, or core methods, from being overridden, use thefinal modifier. In the example below, methodAtt is declared as final, and so it cannot be overridden in any class that extends Attribute.
public class Attribute
{
    int objectVariable;
}
final void methodAtt()
{
    //Some statements
}
NoteNote
You should not specify new or finalize methods as final.
For more information about inheritance in X++, see Creating a Subclass.



Overloading is where there is more than one method with the same name, but the methods have different signatures (return type or parameter lists or both).
Overriding is where the superclass's implementation of a method is altered by the subclass's implementation of the method, but the signatures of both methods are the same.

3) DictTable and DictField Class


DictTable class is used to access information ralated to table. (if you want to access the fields of a record, where you do not know the field names ex:- table_name.(field_id)
)

DictField class is used to access information ralated to table fields.


    static void dictJob(Args _args)
{
    DictTable   dictTable = new DictTable(tableNum(CustTable));
    DictField   dictField;
    int         counter, fieldId;

    CustTable   custTable;
    anytype     value;

    select firstonly custTable;

    for (counter = 1; counter <= dictTable.fieldCnt(); counter++)
    {
        fieldId = dictTable.fieldCnt2Id(counter);
        dictField = new DictField(tableNum(CustTable), fieldId);

        if (!dictField.isSystem())
        {
            value = custTable.(fieldId); // value of the record will display
            if(value)
            {
                info(strFmt('%1 = %2',
                            dictField.label(), // field name will display
                            any2str(value)));
            }
        }
    }
}


4) Difference between Array collection class and x++ arry class

An Array collection class can hold the objects.
x++ array class holds primitive data types such as str,int

5) What should we use to increase performance while inserting, updating or deleting records from a table?
ANS:
·         RecordSortedList: Allows you to insert multiple records in one database trip. Use the RecordSortedList construct when you want a subset of data from a particular table, and when you want it sorted in an order that does not currently exist as an index.
Student student;

RecordSortedList recordSortedList = new RecordSortedList(tablenum(Student));

recordSortedList .sortOrder(fieldname2id(tablenum(Student),’StudentId’));


student.clear();
student.StudentID=”123″;
student.FirstName=”DOM”;
student.LastName=”FED”;
recordSortedList.ins(student);

student.clear();
student.StudentID=”456″;
student.FirstName=”TOM”;
student.LastName=”GED”;
recordSortedList.ins(student);

 student.clear();
student.StudentID=”789″;
student.FirstName=”ROM”;
student.LastName=”TED”;
recordSortedList.ins(student);

recordSortedList.insertDatabase();

·         RecordInsertList: Allows you to insert multiple records in one database trip. Use the RecordInsertList construct when you do not need to sort the data.
·         insert_recordset: Allows you to copy multiple records from one or more tables directly into another table on a single database trip.
·         update_recordset: Allows you to update multiple rows in a table on a single database trip.
·         delete_from Allows you to delete multiple records from the database on a single database trip.

6) Difference between update and doupdate
The doUpdate table method updates the current record with the contents of the buffer. This method also updates the appropriate system fields.
The doUpdate method should be used when the update method on the table is to be bypassed. Suppose you have overridden the update method of the table but sometime there is a situation when you don't want the code written in the overridden update method to be executed and at the same time want any selected record of that table to be updated. In such situation you should call the table.doupdate() method instead of table.update() method.

7) Collection Classes

you cannot store objects in arrays (x++ class) or containers. The Microsoft Dynamics AX collection classes have been designed for storing objects. 

Below are collection classes: Set , Map , List , Array (Collection class)

A Set is used for the storage and retrieval of data from a collection in which the members are unique. The values of the members serve as the key according to which the data is automatically ordered. Thus, it differs from a List collection class where the members are placed into a specific position, and not ordered
automatically by their value.

static void Set(Args _args)
{
    Set setOne;
    Set setTwo;
    SetEnumerator enumerator;
    Int value;
    setOne = new Set(types::Integer);
    setOne.add(4);
    setOne.add(6);
    setOne.add(3);
   
    enumerator = setOne.getEnumerator();
    while (enumerator.moveNext())
    {
        value = enumerator.current();
        info(strFmt("%1",value));      
    }
}

Output :- 3
                 4
                 6

A List object contains members that are accessed sequentially. Lists are structures that can contain members of any X++ type. All the members in the same list must be of the same type.

static void List(Args _args)
{
    List integerList = new List(Types::Integer);
    ListEnumerator enumerator;
    // Add some elements to the list
    integerList.addEnd(1);
    integerList.addEnd(4);
    integerList.addEnd(3);
    // Set the enumerator
    enumerator = integerList.getEnumerator();
    // Go to beginning of enumerator
    enumerator.reset();
    //Go to the first element in the List
    enumerator.moveNext();
    // Print contents of first and second elements
    info(strfmt("%1", enumerator.current()));
    enumerator.moveNext();
    info(strfmt("%1", enumerator.current()));
    enumerator.moveNext();
    info(strfmt("%1", enumerator.current()));
}

Output :- 1
                 4
                 3

A Map object associates one value (the key) with another value. Both the key and value can be of any valid X++ type, including objects. The types of the key and value are specified in the declaration of the map. The way in which maps are implemented means that access to the values is very fast.

static void Map(Args _args)
{
    Map mapTest;
    MapEnumerator enumerator;
  
    mapTest = new Map(Types::String, Types::Integer);
   
    mapTest.insert("One", 1);
    mapTest.insert("Two", 2);
   
    enumerator = mapTest.getEnumerator();
    while (enumerator.moveNext())
    {
        info(strfmt("Key - %1 , Value  - %2.",enumerator.currentKey(),enumerator.currentValue()));
    }
}

Output:- Key - One , Value  - 1.
                Key - Two , Value  - 2.

8) Difference between Containers and Temp tables
·         Data in containers are stored and retrieved sequentially, but a temporary table enables you to define indexes to speed up data retrieval.
·         Containers provide slower data access if you are working with many records. However, if you are working with only a few records, use a container.
·         Another important difference between temporary tables and containers is how they are used in method calls. When you pass a temporary table into a method call, it is passed by reference. Containers are passed by value.
·         When a variable is passed by reference, only a pointer to the object is passed into the method. When a variable is passed by value, a new copy of the variable is passed into the method. If the computer has a limited amount of memory, it might start swapping memory to disk, slowing down application execution. When you pass a variable into a method, a temporary table may provide better performance than a container.

9) Code profier
The Code Profiler measures the execution time of individual lines of code. Use this tool to find performance bottlenecks and to help understand code that was developed by others.
Dev Work space > Tools > Code profiler
If you click on Profile Run button, call tree and profile lines will be there
10) Maps (AOT Element)

Maps define X++ elements that wrap table objects at run time. With a map, you associate a map field with a field in one or more tables. This enables you to use the same field name to access fields with different names but the same data type in different tables. Map methods enable you to create or modify methods that act on the map fields. 
A table can be accessed through more than one map. Typically, if more than one map accesses the same table, each map accesses different subsets of fields in the table.Maps don't define database objects and so they aren't synchronized with the database. 
The benefits of maps include: 
Simplicity - maps provide a single interface to fields in multiple tables. This means that any object referencing the map field can be used against multiple tables without changing any field names. 
Consistency - table fields with varying names can be accessed in code in a consistent manner. For example by using a map, fields named Zip in one table, ZipCode in another, and PostalCode in yet another table can all be accessed by the name ZipCode. 
Code reuse - a map method enables you to add code that runs against the map fields. A single map method prevents the duplication of methods and code on each table. 
An example of a map in Microsoft Dynamics AX is the Address map, which can be used to access fields in two tables (among others) called Address and CustVendTransportPointLine. This enables developers to use one Address map object to access common address fields and methods. 

Map Elements: In Microsoft Dynamics AX, maps are located in the Application Object Tree (AOT) under the Data Dictionary\Maps node. Each map has four primary elements: 
- Fields 
- Field Groups 
- Mappings 
- Methods 

Fields: The Fields node contains the map field elements. Each field must be the same data type as the field to which it's associated. Use the ExtendedDataType property to specify the map field's data type if the map field is associated with a table field that's based on an extended data type. 
Field Groups: The Field Groups node contains field groups that group together fields that logically belong together. Field groups in maps work the same way they do in tables. For more information about field groups, see Best Practices for Field Groups, Defining Field Groups, and How to: Create a Field Group. 
Mappings: The Mappings node is where the map fields are associated with table fields. Directly under the Mappings node are the MappingTable objects. Each MappingTable object specifies a table that the map is associated with. Under the MappingTable object are the field mappings that associate a map field with a table field. If a field exists in the map with no associated field in a particular table just leave the MapFieldTo property blank. 
Methods: This node displays all the methods available from a map. In this node you can add a new method or you can override methods on the xRecord kernel class and add your own code. 

Map methods are useful because code that acts on the map fields can be encapsulated in a map method instead of being in multiple table methods. For example, the AddressMap has a formatAddress method that formats the address consistently whether the map references the Address table or the CustTable table. 

11) Temp Tables

From a developer's perspective, temporary tables store data in the same way as normal physical tables, except that the data is automatically dropped when no longer required.
They are useful in two common situations
1.    As the datasource for a form or report, where the original data is too complex to be easily queried.
2.    As temporary storage during complicated processing, to hold the results midway through the process.
[edit]Types of temporary tables
Prior to Dynamics Ax version Ax 2012, only one type of temporary table was available. In Ax 2012, however, the Temporary property on tables was replaced with a new property: TableType, which has three possible values:
§  Regular - a standard physical table
§  InMemory - the type of temporary table which existed in the previous versions of Dynamics Ax. Such tables are held in memory and written to a local disk file once they grow beyond a certain point
§  TempDB - a new option in Ax 2012. They are "physical" temporary tables held in the SQL Server database.
The new TempDB tables operate in a similar manner to InMemory tables but support more features from standard physical tables:
§  More powerful joins with physical tables are possible, and are properly supported by the database
§  Can be per-company or global
Support for normal tts transactions

  ==============================================================



AOD files path:-

C:\Program Files\Microsoft Dynamics AX \ 60 \ Server\ MicrosoftDynamicsAX\bin \Application \Appl \Standard

The following table shows the names of the layers in different versions of Microsoft Dynamics AX.

Microsoft Dynamics AX 4.0 layer
Microsoft Dynamics AX 2009 layer
Microsoft Dynamics AX 2012 layer(Rename to this)
axbup.aod
axbup.aod
axisp.aod
axbus.aod
axbus.aod
axisv.aod
axlop.aod
axsl3.aod
axslp.aod
axlos.aod
axsl2.aod
axsln.aod
axdip.aod
axsl1.aod
axfpp.aod
axdis.aod
axhfx.aod
axfpk.aod

Model


A model is a set of elements in a given layer. Each layer consists of one or more models. Each layer contains one system-generated model that is specific to that layer. Every element in a layer belongs to only one model. In other words, no element can belong to two models in the same layer, and every element must belong to a model.

A model is permanently associated with the layer that the model was created in. If you need to move one of your models from one layer to another, you must create a project from the model in the Application Object Tree (AOT), export the project as an xpo file, create a target model in the desired layer, delete the original model to avoid having to resolve layer conflicts, and import the xpo file to the target model. If you are moving elements between models in the same layer, you can use the Move to model command in the AOT.

Models are stored in the model store. The model store is a database in which all application elements for Microsoft Dynamics AX are stored. Customizations are also stored in the model store. The model store replaces the Application Object Data (AOD) files that were used in earlier versions of Microsoft Dynamics AX. Models that have been installed in the model store are used at run time.

Models can be exported to files that have the .axmodel extension. These files are called model files. Model files are deployment artifacts. Model files can be signed with strong name signing and Microsoft Authenticode signing.

Models can be exported to files that have the .axmodel extension

Models are logical group of element like tables and classes. In AX 2012 elements can be group and store in the model file. Model files are easy to create, export, import and this can be uninstalled from the system when not required.
Models can manage through following tools.
·         AXUtil.exe command-line utility.
·         Programmatically; using axutilib.dll
·         PowerShell.

Create Model:-
1)     using Developer workspace

Tools > Model management > Create model


2)    Using AXUtil

C:\Program Files\Microsoft Dynamics AX\60\Server\MicrosoftDynamicsAX\bin> axutil create /model:SuniTest /layer:USR
Create Project from model:-
Developer workspace > Tools > Model management > Create Project from model
Export Model
Syntax:  axutil export /model:<modelname> /file:<filename>
C:\Program Files\Microsoft Dynamics AX\60\ManagementUtilities>axutil export /model:"SuniTest"  /file:"ExportModel_TestSuni"
Import Model
Syntax:  axutil import /file:<filename>
C:\Program Files\Microsoft Dynamics AX\60\ManagementUtilities> axutil  import /file:” ExportModel_TestSuni.axmodel”
Delete Model
Syntax: AxUtil delete /model:"My Model"
 =============================================================================


Sales Order
SalesOrder Main list page -> SalesTableListPage(Form) , SalesTable (Table)  
Salesorder Header and Line view page -> SalesTable (Form) , SalesLine(Table) 

Purchase Order

Purchase Order Main list page ->  PurchTableListPage(Form), PurchaseTable (Table)
Purchase order Header and Line view page -> PurchTable(Form), PurchLine (Table)

When we are doing Confirmation/Packlingslip/Invoice , it will open one form related table

Classes: - SalesFormLetter_Confirm, SalesFormLetter_PackingSlip, SalesFormLetter_Invoice, PurchFormLetter_Invoice, PurchFormLetter_PackingSlip

Tables: - SalesParmTable, PurchParmTable ( when u r doing invoice/pakingslip,one form will open.These tables are related to that forms)
Form: - SalesEditLines, PurchEditLines (when u r doing invoice/pakingslip, one form will open.These forms are related to that forms)
Ledger
GeneralJournal :- main form and table -> LedgerJournalTable(Form,Table)
Lines form -> LedgerJournalTransDaily(Form), LedgerJournalTrans(Table)
For ‘Post’  and ‘PostandTransfer’ button means when u post the journal -> LedgerJournalPost(class) and LedgerJournalCheckPost (Class)

For ‘Validate’ botton -> LedgerJournalCheck (Class)
Inventory
Inventory Movement/Transfrer (when moving items from one inventory to another inventory) - >InventJournalCheckPost


  ========================================================================================


What are the best practices you follow?
1)      Select statement
·         If you are going to use only the first record or if only one record can be found, use the    firstOnly   qualifier. This optimizes the select statement for only one record.
·         The index, order by, and where statements are indented once relative to the select or while select statements.

select firstOnly ledgerTrans
     index hint DateIdx
    order by accountNum, transDate
    where ledgerTrans.accountNum >= '40000'    
        && ledgerTrans.accountNum <= '99999'    
        && ledgerTrans.transDate >= 26\04\1999
        && ledgerTrans.transDate <= 02\05\1999;

2)     Use switch statements instead of nested if...else statements.
3)     ttsBegin and ttsCommit
4)     Try / Catch
Always create a try/catch deadlock/retry loop around database transactions that might lead to deadlocks.
            Whenever you have a retry, all the transient variables must be set back to the value they had just before the try. The persistent variables (that is, the database and the Infolog) are set back automatically by the throw that leads to the catch/retry.

               try
         {
             this.createJournal();
             this.printPosted();
         }
         catch (Exception::Deadlock)
         {
             this.removeJournalFromList();
             retry;
         }
5)     The throw statement automatically initiates a ttsAbort, which is a database transaction rollback.
           The throw statement should be used only if a piece of code cannot do what it is expected to do. The throw statement should not be used for more ordinary program flow control.
Always place an explanation of the throw in the Infolog before the actual throw.

Do not use ttsAbort directly; use throw instead.

6)     Use DateTimeUtil::getSystemDateTime instead of systemDateGet or today. The today function uses the date of the machine. The systemDateGetmethod uses the system date in Microsoft Dynamics AX. Only DateTimeUtil::getSystemDateTime compensates for the time zone of the user.
7)     Indentation
An indentation is equivalent to four (4) characters, which corresponds to one tab in the X++ editor.
8)     Extra Semicolon is No Longer 
9)     Constants : Use global macros
10)  Put comments in your code, telling others what the code is supposed to do, and what the parameters are used for.
 ======================================================================