Commit dfbdf4ab authored by Richard Levitte's avatar Richard Levitte Committed by Matt Caswell
Browse files

Fix the evp_test Ctrl keyword processing



Skip the test if the value after ":" is a disabled algorithm, rather
than failing it

Reviewed-by: default avatarMatt Caswell <matt@openssl.org>
parent 586b79d8
Loading
Loading
Loading
Loading
+12 −4
Original line number Diff line number Diff line
@@ -1246,7 +1246,8 @@ static void pkey_test_cleanup(struct evp_test *t)
    EVP_PKEY_CTX_free(kdata->ctx);
}

static int pkey_test_ctrl(EVP_PKEY_CTX *pctx, const char *value)
static int pkey_test_ctrl(struct evp_test *t, EVP_PKEY_CTX *pctx,
                          const char *value)
{
    int rv;
    char *p, *tmpval;
@@ -1258,6 +1259,13 @@ static int pkey_test_ctrl(EVP_PKEY_CTX *pctx, const char *value)
    if (p != NULL)
        *p++ = 0;
    rv = EVP_PKEY_CTX_ctrl_str(pctx, tmpval, p);
    if (p != NULL && rv <= 0 && rv != -2) {
        /* If p has an OID assume disabled algorithm */
        if (OBJ_sn2nid(p) != NID_undef || OBJ_ln2nid(p) != NID_undef) {
            t->skip = 1;
            rv = 1;
        }
    }
    OPENSSL_free(tmpval);
    return rv > 0;
}
@@ -1271,7 +1279,7 @@ static int pkey_test_parse(struct evp_test *t,
    if (strcmp(keyword, "Output") == 0)
        return test_bin(value, &kdata->output, &kdata->output_len);
    if (strcmp(keyword, "Ctrl") == 0)
        return pkey_test_ctrl(kdata->ctx, value);
        return pkey_test_ctrl(t, kdata->ctx, value);
    return 0;
}

@@ -1391,7 +1399,7 @@ static int pderive_test_parse(struct evp_test *t,
    if (strcmp(keyword, "SharedSecret") == 0)
        return test_bin(value, &kdata->output, &kdata->output_len);
    if (strcmp(keyword, "Ctrl") == 0)
        return pkey_test_ctrl(kdata->ctx, value);
        return pkey_test_ctrl(t, kdata->ctx, value);
    return 0;
}

@@ -1812,7 +1820,7 @@ static int kdf_test_parse(struct evp_test *t,
    if (strcmp(keyword, "Output") == 0)
        return test_bin(value, &kdata->output, &kdata->output_len);
    if (strncmp(keyword, "Ctrl", 4) == 0)
        return pkey_test_ctrl(kdata->ctx, value);
        return pkey_test_ctrl(t, kdata->ctx, value);
    return 0;
}