Note: this repository is infrequently maintained.
A sample generator template is just a json document, so of course you can write one by hand, but why bother? We hope you'll take advantage of the tooling provided here to make it easy for any developer with some javascript knowledge to write, test and deploy new Sample Generator Templates.
Install node.js.
Install the Refocus Sample Generator Template Utilities.
$ npm install -g @salesforce/refocus-sample-generator-template-utils
Run sgtu-init <projectName>
to create a new Refocus Sample Generator Template project.
$ sgtu-init <projectName> [--transform <exampleName>] [--connection <exampleName>]
The optional transform
and connection
arguments can initialize your project based on examples in the /examples
directory.
Transform Examples:
mockBulk
- creates mock samples based only on the aspects and subjects passed in.mockBySubject
- creates mock samples based only on the aspects and subject passed in.basicBulk
- creates samples from a basic json response for bulk requests.basicBySubject
- creates samples from a basic json response for bySubject requests.errorHandlersBulk
- example errorHandlers for bulk requestserrorHandlersBulk
- example errorHandlers for bySubject requestshelpers
- example helper functionsrandomNumbers
- a bulk transform example using helpers
Connection Examples:
basic
- specifies a url string and headers objectbasicSubstitution
- specifies a url string and headers object with substitution variablesconcatenateAspects
- generates a url based on the provided aspect namesconcatenateSubjectsAndAspects
- generates a url based on the provided aspect and subject nameshelpers
- example helper functions
After running the sgtu-init
command, your project will be initialized with the following resources to help you get started:
/README.md
- since of course you will be publishing this on github!/[your-template-name].json
- sample generator template json/transform/transform.js
- implement your transform function here/transform/testTransform.js
- implement unit tests for your transform function here/connection/connection.js
- implement your connection here/connection/testConnection.js
- implement unit tests for your connection here
Project initialization also adds some dependencies and scripts to your package.json which will help you validate, test, build and install your sample generator template. Note that these are copied from this project, so if you haven't updated this project in a while you should run npm update
before running sgtu-init
.
- @salesforce/refocus-collector-eval
- chai
- chai-url
- istanbul
- mocha
deploy
test
test-connection
test-transform
validate
Go to /connection/connection.js
and implement either url
or toUrl
.
-
url
(String) You may embed substitution variables in the string using double curly braces, e.g. http://www.xyz.com?id={{key}}. The variable names must all be defined in thecontextDefinition
. Omit theurl
attribute if you intend to implement atoUrl
function instead. -
toUrl
(Function) Use this if you need to do more complex transformations to generate a URL, rather than just simple variable substitutions. Implement your logic in the function body that is already stubbed out. The function must return a string. The function body has access to these variables:context
- a reference to the sample generator context data, with defaults applied.aspects
- an array of one or more aspects as specified by the sample generator. Each object in the array has a "name" attribute.subjects
- an array of one or more subjects as specified by the sample generator.
You can also optionally implement headers
if you need to send custom headers in the request:
headers
(Object, optional) For each named header, if you define it using an object, the Sample Generator is expected to provide the value; if you define it with a string, the header is set using that value. You may embed substitution variables in the string values using double curly braces, e.g. Accept: 'application/{{contentType}}. The variable names must all be defined in thecontextDefinition
.
Write your tests in the stubbed out /connection/testConnection.js
file.
Go to /transform/transform.js
and implement your logic in the function which is already stubbed out in that file. The function must return an array of samples. The function body has access to these variables:
context
- a reference to the sample generator context data, with defaults applied.aspects
- an array of one or more aspects as specified by the sample generator. Each object in the array has a "name" attribute.subject
- if connection.bulk is set to false, this is a reference to the subject.subjects
- if connection.bulk is set to true, this is reference to the array of subjects.res
- a reference to the HTTP response. See https://nodejs.org/api/http.html#http_class_http_incomingmessage for more details on the format of the HTTP response. Typically, the body of the response will be in res.body or res.text, depending on the content type.- Note that you can always get access to the data source's url using
res.path
, if, for example, you want to add a related link to the data source.
- Note that you can always get access to the data source's url using
Provide guidance for the developer to answer stuff like “how are you handling error type x?”, “what happens if y is missing?”, “what does the expected res look like?”, describe your algorithm in user-readable form, etc. — these things can go into a description, etc.
Response Validation: If you want the response to be validated before being passed to the transform, you can define the expected response in the responseValidation attribute in this file. It must be a valid JSON Schema. If the response is invalid, error samples will be automatically created with the error message from the failed validation.
Write your tests in the stubbed out /transform/testTransform.js
file.
Update the contextDefinition attributes in connection/connection.js
and transform/transform.js
to define any variables you need to make available to your url or headers (via double curly braces) or to your toUrl and transform functions via the functions' context argument ctx
.
If there is a variable that will be used in both the connection and transform, define it in both places. Otherwise, you only need to define it in the file it will be used in.
Context Variables defined here will be copied to the Sample Generator Template JSON file. You can also define them directly in the SGT, and leave it blank in the connection and transform files.
Each key defined here must provide an object with the following attributes:
description
(String, required) - provide enough detail for the user to understand what value to providerequired
(Boolean, optional, default =false
) - set totrue
if your users must provide a value for this context variable in their sample generators.encrypted
(Boolean, optional, default =false
) - set totrue
if the value specified in the sample generator is sensitive and should be stored encrypted. Use this to store credentials for the remote data source, to be accessed inheaders
orurl
/toUrl
.default
(Any, optional) - a value to populate the context variable when your users do not provide a value in their sample generators.
If you need to change the method or the timeout used in the request, edit the connection attribute of the generated json file directly:
method
(String, default=GET
[DELETE
|GET
|HEAD
|PATCH
|POST
|PUT
])timeout
(Number, optional, default=[the Refocus Collector's default value], max=[some hard-coded max]) - the number of milliseconds to wait before aborting the request. If undefined or non-numeric values or greater than max, the connection will use the Refocus Collector's default value.
Review all the details in package.json and fill in the following details:
description
- provide some guidance about what would make a good descriptiontags
- optional but recommended (each keyword is /[a-zA-Z0-9-_]+/ and separated by a space)author
name
email
url
repository
type
- defaults to giturl
- optional but recommended
These scripts have been added to your package.json
:
test
test-connection
test-transform
You can run any of these scripts from the command line by calling npm run [SCRIPT-NAME]
.
Validates the template json file.
$ npm run validate
Once your tests are passing, assemble the sample generator template to prepare for installation into Refocus.
$ npm run build
Note: You cannot run build if any tests are failing OR if code coverage is below [TODO]%. This script also runs validate
on the generated template json.
It is highly recommended to put the entire project under source control, e.g. github, for version control and sharing.
Upload your brand new sample generator template into an instance of Refocus. Note: Upload should run test and build and validate before actually uploading.
$ npm run deploy <templateFile> <isPublished> <refocusUrl> <refocusToken>
$ npm run deploy my-sgt.json isPublished=true www.example.com abcdefghijklmnopqrstuvwxyz
If you update your sample generator template, you must increment the version attribute. The version must be in the form of MAJOR.MINOR.PATCH
. Increment the MAJOR
version when you make incompatible API changes; increment the MINOR
version when you add functionality in a backwards-compatible manner; increment the PATCH
version when you make backwards-compatible bug fixes. See http://semver.org/ for more information on semantic versioning.