xrm-mock-generator
Version:
Generates a mock Xrm.Page object. Commonly used by xrm-mock to test Dynamics 365 client-side customisations.
102 lines (81 loc) • 2.85 kB
Markdown
## :book: xrm-mock-generator
Generates a mock Xrm.Page object.
Commonly used by `xrm-mock` to test Dynamics 365 client-side customisations.
## Usage
- install via `npm install xrm-mock-generator`
- import `var XrmMockGenerator = require("xrm-mock-generator");`
- initialise a global Xrm object `var Xrm = XrmMockGenerator.initialise();`
You now have a global `Xrm` object, as if you had loaded a form in CRM.
### Add additional attributes
Create a <b>string</b> attribute and add it to global.Xrm
```javascript
var stringAttribute = XrmMockGenerator.Attribute.createString("firstname", "Joe");
```
#### Boolean Attribute
```javascript
var boolAttribute = XrmMockGenerator.Attribute.createBool("new_havingFun", true);
```
#### Date Attribute
```javascript
var dateAttribute = XrmMockGenerator.Attribute.createDate("birthdate", new Date(1980, 12, 25));
```
#### DateTime Attribute
```javascript
var dateTimeAttribute = XrmMockGenerator.Attribute.createDateTime("birthdate", new Date(1980, 12, 25));
```
#### Number Attribute
```javascript
var numberAttribute = XrmMockGenerator.Attribute.createNumber("units", 2, 0, 10, 0);
```
#### OptionSet Attribute
```javascript
var optionSetAttribute = XrmMockGenerator.Attribute.createOptionSet("countries", [
{ "Austria" : 0 },
{ "France", : 1 },
{ "Spain", 2 }
]);
```
#### Lookup Attribute
```javascript
var lookupAttribute = XrmMockGenerator.Attribute.createLookup("primarycustomerid", {
id: "{00000000-0000-0000-0000-000000000000}",
entityType: "contact",
name: "Joe Bloggs"
});
```
## Example
This example showcases a contact form that changes the contact's firstname from Joe to Bob when the form is loaded.
#### src/contact.js
```javascript
(function () {
"use strict";
var Contact = () => { };
Contact.prototype.onLoad = function () {
Xrm.Page.getAttribute("firstname").setValue("Bob");
}
// node
module.exports = new Contact();
// browser
global.Contact = new Contact();
}());
```
#### test/contact.test.js
```javascript
describe("Contact Form", () => {
var XrmMockGenerator = require("xrm-mock-generator");
var ContactForm = require("../src/contact.js");
beforeEach(() => {
XrmMockGenerator.initialise();
XrmMockGenerator.createString("firstname", "Joe");
});
describe("default", () => {
expect(Xrm.Page.getAttribute("firstname").getValue()).toBe("Joe"); // true
});
describe("onLoad", () => {
Contact.onLoad();
expect(Xrm.Page.getAttribute("firstname").getValue()).toBe("Bob"); // true
});
});
```
## :heart: Roadmap
- Automatically create attribute metadata from a Dynamics 365 instance