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