|
@@ -58,6 +58,47 @@ describe('Strategy', function() {
|
|
|
.authenticate();
|
|
|
}); // should verify address
|
|
|
|
|
|
+ it('should verify address and chain id', function(done) {
|
|
|
+ chai.passport.use(new Strategy(function(address, chainId, cb) {
|
|
|
+ expect(address).to.equal('0xCC6F4DF4B758C4DE3203e8842E2d8CAc564D7758');
|
|
|
+ expect(chainId).to.equal(1);
|
|
|
+ return cb(null, { id: '248289761001' });
|
|
|
+ }))
|
|
|
+ .request(function(req) {
|
|
|
+ req.connection = {};
|
|
|
+ req.headers.host = 'localhost:3000';
|
|
|
+ req.body = {
|
|
|
+ message: 'localhost:3000 wants you to sign in with your Ethereum account:\n' +
|
|
|
+ '0xCC6F4DF4B758C4DE3203e8842E2d8CAc564D7758\n' +
|
|
|
+ '\n' +
|
|
|
+ 'Sign in with Ethereum to the app.\n' +
|
|
|
+ '\n' +
|
|
|
+ 'URI: http://localhost:3000\n' +
|
|
|
+ 'Version: 1\n' +
|
|
|
+ 'Chain ID: 1\n' +
|
|
|
+ 'Nonce: VjglqeaSMDbPSYe0K\n' +
|
|
|
+ 'Issued At: 2022-06-07T16:28:10.957Z',
|
|
|
+ signature: '0xb303d03782c532e2371e3d75a8b2b093c2dceb5faed5d07d6506be96be783245515db6ad55ad6d598ebdf1f7e1c5cb0d24e7147bbad47d3b9d8dfbcfab2ddcc71b'
|
|
|
+ };
|
|
|
+ req.session = {
|
|
|
+ messages: [],
|
|
|
+ 'ethereum:siwe': {
|
|
|
+ nonce: 'VjglqeaSMDbPSYe0K'
|
|
|
+ }
|
|
|
+ };
|
|
|
+ })
|
|
|
+ .success(function(user, info) {
|
|
|
+ expect(user).to.deep.equal({ id: '248289761001' });
|
|
|
+ expect(info).to.be.undefined;
|
|
|
+ expect(this.session).to.deep.equal({
|
|
|
+ messages: []
|
|
|
+ });
|
|
|
+ done();
|
|
|
+ })
|
|
|
+ .error(done)
|
|
|
+ .authenticate();
|
|
|
+ }); // should verify address and chain id
|
|
|
+
|
|
|
it('should fail when URI is invalid', function(done) {
|
|
|
chai.passport.use(new Strategy(function(address, cb) {
|
|
|
expect(address).to.equal('0xCC6F4DF4B758C4DE3203e8842E2d8CAc564D7758');
|