未验证 提交 28e11006 编写于 作者: O openharmony_ci 提交者: Gitee

!6560 【OpenHarmony 3.2.8.5】【安全子系统】【master】加解密新增用例

Merge pull request !6560 from qiaozzzh/1117_1
......@@ -55,7 +55,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_0200
* @tc.name Test MD5 for MD digest algotithm
* @tc.name Test SHA1 for MD digest algotithm
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_MD_0200", 0, async function (done) {
......@@ -71,7 +71,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_0300
* @tc.name Test MD5 for MD digest algotithm
* @tc.name Test SHA224 for MD digest algotithm
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_MD_0300", 0, async function (done) {
......@@ -87,7 +87,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_0400
* @tc.name Test SHA384 for MD digest algotithm
* @tc.name Test SHA256 for MD digest algotithm
* @tc.desc Use the Callback Style of Interface
*/
it("Security_crypto_framework_MD_0400", 0, async function (done) {
......@@ -102,7 +102,7 @@ export default function DigestAlgorithmJsunit() {
});
/**
* @tc.number Security_crypto_framework_MD_
* @tc.number Security_crypto_framework_MD_0500
*
* @tc.name Test SHA384 for MD digest algotithm
* @tc.desc Use the Callback Style of Interface
......@@ -120,7 +120,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_0600
* @tc.name Test SHA384 for MD digest algotithm
* @tc.name Test SHA512 for MD digest algotithm
* @tc.desc Use the Callback Style of Interface
*/
it("Security_crypto_framework_MD_0600", 0, async function (done) {
......@@ -136,7 +136,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_0700
* @tc.name Test SHA384 for MD digest algotithm
* @tc.name The encryption and decryption framework supports MD calculation, and the algorithm parameters are abnormal
* @tc.desc Use the Callback Style of Interface
*/
it("Security_crypto_framework_MD_0700", 0, async function (done) {
......@@ -152,7 +152,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_0800
* @tc.name Test SHA384 for MD digest algotithm
* @tc.name The encryption and decryption framework supports MD calculation, and the algorithm parameter is NULL
* @tc.desc Use the Callback Style of Interface
*/
it("Security_crypto_framework_MD_0800", 0, async function (done) {
......@@ -168,7 +168,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_0900
* @tc.name Test SHA384 for MD digest algotithm
* @tc.name The encryption and decryption framework supports MD calculation, and the Datablob value to be calculated is a super large value
* @tc.desc Use the Callback Style of Interface
*/
it("Security_crypto_framework_MD_0900", 0, async function (done) {
......@@ -184,7 +184,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_MD_1000
* @tc.name Test SHA384 for MD digest algotithm
* @tc.name The encryption and decryption framework supports MD calculation, and the Datablob value to be calculated is abnormal
* @tc.desc Use the Callback Style of Interface
*/
it("Security_crypto_framework_MD_1000", 0, async function (done) {
......@@ -216,7 +216,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0200
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name Test SHA224 for HMAC digest algorithm
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_HMAC_0200", 0, async function (done) {
......@@ -232,7 +232,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0300
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name Test SHA256 for HMAC digest algorithm
* @tc.desc Use the Callback Style of Interface
*/
it("Security_crypto_framework_HMAC_0300", 0, async function (done) {
......@@ -248,7 +248,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0400
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name Test SHA384 for HMAC digest algorithm
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_HMAC_0400", 0, async function (done) {
......@@ -264,7 +264,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0500
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name Test SHA512 for HMAC digest algorithm
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_HMAC_0500", 0, async function (done) {
......@@ -280,7 +280,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0600
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name The encryption and decryption framework supports HMAC calculation, and HMAC algorithm parameters are abnormal
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_HMAC_0600", 0, async function (done) {
......@@ -296,7 +296,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0700
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name The encryption and decryption framework supports HMAC calculation, and the key algorithm parameters are abnormal
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_HMAC_0700", 0, async function (done) {
......@@ -312,7 +312,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0800
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name The encryption and decryption framework supports HMAC calculation, and the Datablob of HMAC to be calculated is abnormal
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_HMAC_0800", 0, async function (done) {
......@@ -328,7 +328,7 @@ export default function DigestAlgorithmJsunit() {
/**
* @tc.number Security_crypto_framework_HMAC_0900
* @tc.name Test SHA1 for HMAC digest algorithm
* @tc.name The encryption and decryption framework supports HMAC calculation, and the Datablob of HMAC to be calculated is very large
* @tc.desc Use the Promise Style of Interface
*/
it("Security_crypto_framework_HMAC_0900", 0, async function (done) {
......
......@@ -156,6 +156,7 @@ async function encryptAndDecryptNormalProcess(
cipherAlgoName,
paramType
) {
var updateOutputdata;
var globalCipherText;
var globalKey;
var globalText = "aaa this is test! this is test! bbb";
......@@ -230,13 +231,11 @@ async function encryptAndDecryptNormalProcess(
return updateCipher(cipherGenerator, decryptMode, globalCipherText);
})
.then((updateOutput) => {
updateOutputdata = uInt8ArrayToString(updateOutput.data);
console.warn(
"[Callback]decrypt update out: " +
uInt8ArrayToString(updateOutput.data)
);
expect(
uInt8ArrayToString(updateOutput.data) == globalText
).assertTrue();
return doFinalCipher(cipherGenerator, decryptMode, null);
})
.then((finalOutput) => {
......@@ -245,8 +244,15 @@ async function encryptAndDecryptNormalProcess(
} else {
console.log(
"[Callback]decrypt doFinal out hex: " +
uInt8ArrayToShowStr(finalOutput.data)
uInt8ArrayToString(finalOutput.data)
);
console.log(
"[Callback]Decrypt plaintext data: " +
updateOutputdata + uInt8ArrayToString(finalOutput.data)
);
expect(
updateOutputdata + uInt8ArrayToString(finalOutput.data) == globalText
).assertTrue();
}
resolve();
})
......@@ -262,6 +268,7 @@ async function convertKeyEncryptAndDecryptProcess(
cipherAlgoName,
paramType
) {
var updateOutputdata;
var globalCipherText;
var globalKey;
var globalText = "aaa this is test! this is test! bbb";
......@@ -341,13 +348,11 @@ async function convertKeyEncryptAndDecryptProcess(
return updateCipher(cipherGenerator, decryptMode, globalCipherText);
})
.then((updateOutput) => {
updateOutputdata = uInt8ArrayToString(updateOutput.data);
console.warn(
"[Callback]decrypt update out: " +
uInt8ArrayToString(updateOutput.data)
);
expect(
uInt8ArrayToString(updateOutput.data) == globalText
).assertTrue();
return doFinalCipher(cipherGenerator, decryptMode, null);
})
.then((finalOutput) => {
......@@ -355,9 +360,16 @@ async function convertKeyEncryptAndDecryptProcess(
console.error("[Callback]decrypt doFinal out is null");
} else {
console.log(
"[Callback]decrypt doFinal out hex: " +
uInt8ArrayToShowStr(finalOutput.data)
"[promise]decrypt doFinal out hex: " +
uInt8ArrayToString(finalOutput.data)
);
console.log(
"[promise]Decrypt plaintext data: " +
updateOutputdata + uInt8ArrayToString(finalOutput.data)
);
expect(
updateOutputdata + uInt8ArrayToString(finalOutput.data) == globalText
).assertTrue();
}
resolve();
})
......
......@@ -154,11 +154,153 @@ async function doFinalCipher(cipherGenerator, mode, dataBlob) {
});
}
async function createSymKeyGeneratorFail(
symAlgoName,
) {
return new Promise((resolve, reject) => {
var symKeyGenerator = createSymKeyGenerator(symAlgoName);
resolve(symKeyGenerator);
expect(symKeyGenerator == "Error: create C generator fail.").assertTrue();
if (symKeyGenerator != "Error: create C generator fail.") {
reject();
}
});
}
async function createSymCipherFail(
cipherAlgoName,
) {
return new Promise((resolve, reject) => {
var symKeyGenerator = createSymCipher(cipherAlgoName);
resolve(symKeyGenerator);
expect(symKeyGenerator == "Error: create C cipher fail!").assertTrue();
if (symKeyGenerator != "Error: create C cipher fail!") {
reject();
}
});
}
async function encryptAndDecryptNormalProcessSpecialdata(
symAlgoName,
cipherAlgoName,
paramType
) {
var updateOutputdata;
var globalCipherText;
var globalKey;
var globalText = null;
var encryptMode = cryptoFramework.CryptoMode.ENCRYPT_MODE;
var decryptMode = cryptoFramework.CryptoMode.DECRYPT_MODE;
return new Promise((resolve, reject) => {
var symKeyGenerator = createSymKeyGenerator(symAlgoName);
expect(symKeyGenerator != null).assertTrue();
var cipherGenerator = createSymCipher(cipherAlgoName);
if (cipherGenerator == "Error: create C cipher fail!") {
resolve(cipherGenerator);
}
expect(cipherGenerator != null).assertTrue();
var globalParams = createGlobalParams(symAlgoName, paramType);
generateSymKey(symKeyGenerator)
.then((promiseKey) => {
expect(promiseKey != null).assertTrue();
globalKey = promiseKey;
return initCipher(
cipherGenerator,
encryptMode,
promiseKey,
globalParams
);
})
.then((initData) => {
expect(initData === "init success").assertTrue();
let plainText = { data: stringTouInt8Array(globalText) };
return updateCipher(cipherGenerator, encryptMode, plainText);
})
.then((updateOutput) => {
console.warn(
"[promise]encrypt update out hex:" +
uInt8ArrayToShowStr(updateOutput.data)
);
globalCipherText = updateOutput;
expect(globalCipherText != null).assertTrue();
return doFinalCipher(cipherGenerator, encryptMode, null);
})
.then((finalOutput) => {
if (finalOutput == null) {
} else {
if (
paramType == "genGcmParamsSpec" ||
paramType == "genCcmParamsSpec"
) {
console.warn(
"[promise]encrypt authTag(finalOutput) hex: " +
uInt8ArrayToShowStr(finalOutput.data)
);
globalParams.authTag = finalOutput;
} else {
console.warn(
"[promise]encrypt authTag(finalOutput) hex: " +
uInt8ArrayToShowStr(finalOutput.data)
);
globalCipherText = Array.from(globalCipherText.data);
finalOutput = Array.from(finalOutput.data);
globalCipherText = globalCipherText.concat(finalOutput);
globalCipherText = new Uint8Array(globalCipherText);
globalCipherText = { data: globalCipherText };
}
}
return initCipher(
cipherGenerator,
decryptMode,
globalKey,
globalParams
);
})
.then((initData) => {
expect(initData === "init success").assertTrue();
return updateCipher(cipherGenerator, decryptMode, globalCipherText);
})
.then((updateOutput) => {
updateOutputdata = uInt8ArrayToString(updateOutput.data);
console.warn(
"[promise]decrypt update out: " +
uInt8ArrayToString(updateOutput.data)
);
return doFinalCipher(cipherGenerator, decryptMode, null);
})
.then((finalOutput) => {
if (finalOutput == null) {
console.error("[promise]decrypt doFinal out is null");
} else {
console.log(
"[promise]decrypt doFinal out hex: " +
uInt8ArrayToString(finalOutput.data)
);
console.log(
"[promise]Decrypt plaintext data: " +
updateOutputdata + uInt8ArrayToString(finalOutput.data)
);
expect(
updateOutputdata + uInt8ArrayToString(finalOutput.data) == globalText
).assertTrue();
}
reject();
})
.catch((err) => {
console.error("[promise] encryptProcess catch err:" + err);
resolve(err);
});
});
}
async function encryptAndDecryptNormalProcess(
symAlgoName,
cipherAlgoName,
paramType
) {
var updateOutputdata;
var globalCipherText;
var globalKey;
var globalText = "aaa this is test! this is test! bbb";
......@@ -169,6 +311,9 @@ async function encryptAndDecryptNormalProcess(
var symKeyGenerator = createSymKeyGenerator(symAlgoName);
expect(symKeyGenerator != null).assertTrue();
var cipherGenerator = createSymCipher(cipherAlgoName);
if (cipherGenerator == "Error: create C cipher fail!") {
resolve(cipherGenerator);
}
expect(cipherGenerator != null).assertTrue();
var globalParams = createGlobalParams(symAlgoName, paramType);
......@@ -233,13 +378,11 @@ async function encryptAndDecryptNormalProcess(
return updateCipher(cipherGenerator, decryptMode, globalCipherText);
})
.then((updateOutput) => {
updateOutputdata = uInt8ArrayToString(updateOutput.data);
console.warn(
"[promise]decrypt update out: " +
uInt8ArrayToString(updateOutput.data)
);
expect(
uInt8ArrayToString(updateOutput.data) == globalText
).assertTrue();
return doFinalCipher(cipherGenerator, decryptMode, null);
})
.then((finalOutput) => {
......@@ -248,8 +391,15 @@ async function encryptAndDecryptNormalProcess(
} else {
console.log(
"[promise]decrypt doFinal out hex: " +
uInt8ArrayToShowStr(finalOutput.data)
uInt8ArrayToString(finalOutput.data)
);
console.log(
"[promise]Decrypt plaintext data: " +
updateOutputdata + uInt8ArrayToString(finalOutput.data)
);
expect(
updateOutputdata + uInt8ArrayToString(finalOutput.data) == globalText
).assertTrue();
}
resolve();
})
......@@ -265,6 +415,7 @@ async function convertKeyEncryptAndDecryptProcess(
cipherAlgoName,
paramType
) {
var updateOutputdata;
var globalCipherText;
var globalKey;
var globalText = "aaa this is test! this is test! bbb";
......@@ -344,13 +495,11 @@ async function convertKeyEncryptAndDecryptProcess(
return updateCipher(cipherGenerator, decryptMode, globalCipherText);
})
.then((updateOutput) => {
updateOutputdata = uInt8ArrayToString(updateOutput.data);
console.warn(
"[promise]decrypt update out: " +
uInt8ArrayToString(updateOutput.data)
);
expect(
uInt8ArrayToString(updateOutput.data) == globalText
).assertTrue();
return doFinalCipher(cipherGenerator, decryptMode, null);
})
.then((finalOutput) => {
......@@ -359,8 +508,15 @@ async function convertKeyEncryptAndDecryptProcess(
} else {
console.log(
"[promise]decrypt doFinal out hex: " +
uInt8ArrayToShowStr(finalOutput.data)
uInt8ArrayToString(finalOutput.data)
);
console.log(
"[promise]Decrypt plaintext data: " +
updateOutputdata + uInt8ArrayToString(finalOutput.data)
);
expect(
updateOutputdata + uInt8ArrayToString(finalOutput.data) == globalText
).assertTrue();
}
resolve();
})
......@@ -387,8 +543,133 @@ function ClearMemProcess(symAlgoName) {
});
}
async function encryptAndDecryptNormalProcessSuperdata(
symAlgoName,
cipherAlgoName,
paramType
) {
var updateOutputdata;
var globalCipherText;
var globalKey;
var globalText;
var globalTextLen = 1025;
var i;
var encryptMode = cryptoFramework.CryptoMode.ENCRYPT_MODE;
var decryptMode = cryptoFramework.CryptoMode.DECRYPT_MODE;
var t = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefhijklmnopqrstuvwxyz",n = t.length,s="";
for (i = 0; i < globalTextLen; i++) {
globalText += t.charAt(Math.floor(Math.random() * n));
}
console.warn("globalText1111111111111111111111111111111: " + globalText);
return new Promise((resolve, reject) => {
var symKeyGenerator = createSymKeyGenerator(symAlgoName);
expect(symKeyGenerator != null).assertTrue();
var cipherGenerator = createSymCipher(cipherAlgoName);
if (cipherGenerator == "Error: create C cipher fail!") {
resolve(cipherGenerator);
}
expect(cipherGenerator != null).assertTrue();
var globalParams = createGlobalParams(symAlgoName, paramType);
generateSymKey(symKeyGenerator)
.then((promiseKey) => {
expect(promiseKey != null).assertTrue();
globalKey = promiseKey;
return initCipher(
cipherGenerator,
encryptMode,
promiseKey,
globalParams
);
})
.then((initData) => {
expect(initData === "init success").assertTrue();
let plainText = { data: stringTouInt8Array(globalText) };
return updateCipher(cipherGenerator, encryptMode, plainText);
})
.then((updateOutput) => {
console.warn(
"[promise]encrypt update out hex:" +
uInt8ArrayToShowStr(updateOutput.data)
);
globalCipherText = updateOutput;
expect(globalCipherText != null).assertTrue();
return doFinalCipher(cipherGenerator, encryptMode, null);
})
.then((finalOutput) => {
if (finalOutput == null) {
} else {
if (
paramType == "genGcmParamsSpec" ||
paramType == "genCcmParamsSpec"
) {
console.warn(
"[promise]encrypt authTag(finalOutput) hex: " +
uInt8ArrayToShowStr(finalOutput.data)
);
globalParams.authTag = finalOutput;
} else {
console.warn(
"[promise]encrypt authTag(finalOutput) hex: " +
uInt8ArrayToShowStr(finalOutput.data)
);
globalCipherText = Array.from(globalCipherText.data);
finalOutput = Array.from(finalOutput.data);
globalCipherText = globalCipherText.concat(finalOutput);
globalCipherText = new Uint8Array(globalCipherText);
globalCipherText = { data: globalCipherText };
}
}
return initCipher(
cipherGenerator,
decryptMode,
globalKey,
globalParams
);
})
.then((initData) => {
expect(initData === "init success").assertTrue();
return updateCipher(cipherGenerator, decryptMode, globalCipherText);
})
.then((updateOutput) => {
updateOutputdata = uInt8ArrayToString(updateOutput.data);
console.warn(
"[promise]decrypt update out: " +
uInt8ArrayToString(updateOutput.data)
);
return doFinalCipher(cipherGenerator, decryptMode, null);
})
.then((finalOutput) => {
if (finalOutput == null) {
console.error("[promise]decrypt doFinal out is null");
} else {
console.log(
"[promise]decrypt doFinal out hex: " +
uInt8ArrayToString(finalOutput.data)
);
console.log(
"[promise]Decrypt plaintext data: " +
updateOutputdata + uInt8ArrayToString(finalOutput.data)
);
expect(
updateOutputdata + uInt8ArrayToString(finalOutput.data) == globalText
).assertTrue();
}
resolve();
})
.catch((err) => {
console.error("[promise] encryptProcess catch err:" + err);
reject();
});
});
}
export {
encryptAndDecryptNormalProcess,
convertKeyEncryptAndDecryptProcess,
ClearMemProcess,
createSymKeyGeneratorFail,
createSymCipherFail,
encryptAndDecryptNormalProcessSpecialdata,
encryptAndDecryptNormalProcessSuperdata,
};
......@@ -49,7 +49,7 @@ export default function SecurityRandomJsunit() {
/**
* @tc.number Security_crypto_framework_Random_0200
* @tc.name support security random and set random seed
* @tc.name Support setting random number seed and restart encryption and decryption framework
* @tc.desc the length of random is 32, use callback style of interface
*/
it("Security_crypto_framework_Random_0200", 0, async function (done) {
......@@ -65,8 +65,8 @@ export default function SecurityRandomJsunit() {
/**
* @tc.number Security_crypto_framework_Random_0300
* @tc.name support security random and set random seed
* @tc.desc the length of random is 32, use callback style of interface
* @tc.name Support generating safe random numbers and setting the length of random numbers
* @tc.desc use callback style of interface
*/
it("Security_crypto_framework_Random_0300", 0, async function (done) {
await testSecurityRandomLengthCallback(0)
......@@ -102,8 +102,8 @@ export default function SecurityRandomJsunit() {
/**
* @tc.number Security_crypto_framework_Random_0400
* @tc.name support security random and set random seed
* @tc.desc the length of random is 32, use callback style of interface
* @tc.name Support generating safe random numbers and setting random number seed exceptions
* @tc.desc use callback style of interface
*/
it("Security_crypto_framework_Random_0400", 0, async function (done) {
await testSecurityRandomCallbackSeed(null)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册