11cb0ef41Sopenharmony_ci'use strict';
21cb0ef41Sopenharmony_ci
31cb0ef41Sopenharmony_ciconst common = require('../common');
41cb0ef41Sopenharmony_ciif (!common.hasCrypto)
51cb0ef41Sopenharmony_ci  common.skip('missing crypto');
61cb0ef41Sopenharmony_ci
71cb0ef41Sopenharmony_ciconst assert = require('assert');
81cb0ef41Sopenharmony_ciconst {
91cb0ef41Sopenharmony_ci  generateKeyPair,
101cb0ef41Sopenharmony_ci} = require('crypto');
111cb0ef41Sopenharmony_ci
121cb0ef41Sopenharmony_ci// Test async elliptic curve key generation with 'jwk' encoding and named
131cb0ef41Sopenharmony_ci// curve.
141cb0ef41Sopenharmony_ci['P-384', 'P-256', 'P-521', 'secp256k1'].forEach((curve) => {
151cb0ef41Sopenharmony_ci  generateKeyPair('ec', {
161cb0ef41Sopenharmony_ci    namedCurve: curve,
171cb0ef41Sopenharmony_ci    publicKeyEncoding: {
181cb0ef41Sopenharmony_ci      format: 'jwk'
191cb0ef41Sopenharmony_ci    },
201cb0ef41Sopenharmony_ci    privateKeyEncoding: {
211cb0ef41Sopenharmony_ci      format: 'jwk'
221cb0ef41Sopenharmony_ci    }
231cb0ef41Sopenharmony_ci  }, common.mustSucceed((publicKey, privateKey) => {
241cb0ef41Sopenharmony_ci    assert.strictEqual(typeof publicKey, 'object');
251cb0ef41Sopenharmony_ci    assert.strictEqual(typeof privateKey, 'object');
261cb0ef41Sopenharmony_ci    assert.strictEqual(publicKey.x, privateKey.x);
271cb0ef41Sopenharmony_ci    assert.strictEqual(publicKey.y, privateKey.y);
281cb0ef41Sopenharmony_ci    assert(!publicKey.d);
291cb0ef41Sopenharmony_ci    assert(privateKey.d);
301cb0ef41Sopenharmony_ci    assert.strictEqual(publicKey.kty, 'EC');
311cb0ef41Sopenharmony_ci    assert.strictEqual(publicKey.kty, privateKey.kty);
321cb0ef41Sopenharmony_ci    assert.strictEqual(publicKey.crv, curve);
331cb0ef41Sopenharmony_ci    assert.strictEqual(publicKey.crv, privateKey.crv);
341cb0ef41Sopenharmony_ci  }));
351cb0ef41Sopenharmony_ci});
36