The test harness you should use when writing an ACME challenge strategy
for Greenlock v2.7+ (and v3).
All implementations MUST pass these tests, which is a very easy thing to do (just set()
, get()
, and remove()
).
The tests account for single-domain certificates (example.com
) as well as multiple domain certs (SAN / AltName),
wildcards (*.example.com
), and valid private / localhost certificates. As someone creating a challenge strategy
that's not something you have to take special consideration for - just pass the tests.
Install
npm install --save-dev acme-challenge-test@3.x
Usage
var tester = require("acme-challenge-test");
var challenger = require("./YOUR-CHALLENGE-STRATEGY").create({});
var domain = "example.com";
tester.test("http-01", domain, challenger).then(function() {
console.info("PASS");
});
Reference Implementations
These are plugins that use the v2.7+ (v3) API, and pass this test harness,
which you should use as a model for any plugins that you create.
Example
See example.js
(it works).
Overview
Here's a quick pseudo stub-out of what a test-passing plugin object might look like:
tester.test('http-01', 'example.com', {
set: function (opts) {
var ch = opts.challenge;
return API.set(...);
}
, get: function (query) {
var ch = query.challenge;
return API.get(...).then(function (secret) {
return { keyAuthorization: secret };
});
}
, remove: function (opts) {
var ch = opts.challenge;
return API.remove(...);
}
}).then(function () {
console.info("PASS");
});
Note: The API.get()
, API.set()
, and API.remove()
is where you do your magic up to upload a file to the correct
location on an http serever, set DNS records, or add the appropriate data to the database that handles such things.