diff options
author | Christian Grothoff <christian@grothoff.org> | 2022-12-29 14:47:17 +0100 |
---|---|---|
committer | Christian Grothoff <christian@grothoff.org> | 2022-12-29 14:47:17 +0100 |
commit | 2c19f6a6fb180f059fcaeb193dd387c4d6af21b1 (patch) | |
tree | d7fdd874e84950510f5a7a698007023ed46d80ea /src/testing | |
parent | 689bbc7a201067815cb0975703422854099d19ba (diff) |
-towards fixing the template tests
Diffstat (limited to 'src/testing')
-rw-r--r-- | src/testing/test_merchant_api.c | 201 | ||||
-rw-r--r-- | src/testing/testing_api_cmd_get_template.c | 41 | ||||
-rw-r--r-- | src/testing/testing_api_cmd_post_templates.c | 42 | ||||
-rw-r--r-- | src/testing/testing_api_cmd_post_using_templates.c | 116 |
4 files changed, 195 insertions, 205 deletions
diff --git a/src/testing/test_merchant_api.c b/src/testing/test_merchant_api.c index a4a6dfd9..a53ec442 100644 --- a/src/testing/test_merchant_api.c +++ b/src/testing/test_merchant_api.c @@ -1299,79 +1299,133 @@ run (void *cls, MHD_HTTP_OK, NULL), TALER_TESTING_cmd_merchant_post_templates ("post-templates-t1", - merchant_url, - "template-1", - "a template", - MHD_HTTP_NO_CONTENT), + merchant_url, + "template-1", + "a template", + MHD_HTTP_NO_CONTENT), TALER_TESTING_cmd_merchant_post_templates ("post-templates-t1-idem", - merchant_url, - "template-1", - "a template", - MHD_HTTP_NO_CONTENT), + merchant_url, + "template-1", + "a template", + MHD_HTTP_NO_CONTENT), TALER_TESTING_cmd_merchant_post_templates ("post-templates-t1-non-idem", - merchant_url, - "template-1", - "a different template", - MHD_HTTP_CONFLICT), + merchant_url, + "template-1", + "a different template", + MHD_HTTP_CONFLICT), TALER_TESTING_cmd_merchant_get_templates ("get-templates-t1", + merchant_url, + MHD_HTTP_OK, + "post-templates-t1", + NULL), + TALER_TESTING_cmd_merchant_get_template ("get-template-t1", merchant_url, + "template-1", MHD_HTTP_OK, - "post-templates-t1", - NULL), - TALER_TESTING_cmd_merchant_get_template ("get-template-t1", - merchant_url, - "template-1", - MHD_HTTP_OK, - "post-templates-t1"), + "post-templates-t1"), TALER_TESTING_cmd_merchant_post_templates ("post-templates-t2", - merchant_url, - "template-2", - "a template", - MHD_HTTP_NO_CONTENT), - TALER_TESTING_cmd_merchant_patch_template ("patch-templates-t2", - merchant_url, - "template-2", - "another template", - "", - json_pack ("{s:s}", - "summary", - "EUR"), - MHD_HTTP_NO_CONTENT), + merchant_url, + "template-2", + "a template", + MHD_HTTP_NO_CONTENT), + TALER_TESTING_cmd_merchant_patch_template ( + "patch-templates-t2", + merchant_url, + "template-2", + "another template", + "", + json_pack ("{s:s}", + "summary", + "my new summary"), + MHD_HTTP_NO_CONTENT), TALER_TESTING_cmd_merchant_get_template ("get-template-t2", - merchant_url, - "template-2", - MHD_HTTP_OK, - "patch-templates-t2"), + merchant_url, + "template-2", + MHD_HTTP_OK, + "patch-templates-t2"), TALER_TESTING_cmd_merchant_get_template ("get-template-nx", - merchant_url, - "template-nx", - MHD_HTTP_NOT_FOUND, - NULL), - TALER_TESTING_cmd_merchant_patch_template ("patch-templates-t3-nx", - merchant_url, - "template-3", - "updated template", - "", - json_pack ("{s:s}", - "summary", - "EUR"), - MHD_HTTP_NOT_FOUND), + merchant_url, + "template-nx", + MHD_HTTP_NOT_FOUND, + NULL), + TALER_TESTING_cmd_merchant_patch_template ( + "patch-templates-t3-nx", + merchant_url, + "template-3", + "updated template", + "", + json_pack ("{s:s}", + "summary", + "my new summary"), + MHD_HTTP_NOT_FOUND), + TALER_TESTING_cmd_merchant_post_templates2 ( + "post-templates-t3-amount", + merchant_url, + "template-amount", + "a different template with an amount", + NULL, + json_pack ("{s:s}", + "amount", + "EUR:4"), + MHD_HTTP_NO_CONTENT), + TALER_TESTING_cmd_merchant_post_using_templates ( + "using-templates-t1", + "post-templates-t1", + merchant_url, + "summary-1", + "EUR:10", + MHD_HTTP_OK), + TALER_TESTING_cmd_merchant_post_using_templates ( + "using-templates-t1-amount-missing", + "post-templates-t1", + merchant_url, + "summary-1", + NULL, + MHD_HTTP_CONFLICT), + TALER_TESTING_cmd_merchant_post_using_templates ( + "using-templates-t1-summary-missing", + "post-templates-t1", + merchant_url, + NULL, + "EUR:10", + MHD_HTTP_CONFLICT), + TALER_TESTING_cmd_merchant_post_using_templates ( + "using-templates-t1-amount-conflict", + "post-templates-t3-amount", + merchant_url, + "summary-1", + "EUR:10", + MHD_HTTP_CONFLICT), + TALER_TESTING_cmd_merchant_post_using_templates ( + "using-templates-t1-amount-duplicate", + "post-templates-t3-amount", + merchant_url, + "summary-1", + "EUR:4", + MHD_HTTP_CONFLICT), TALER_TESTING_cmd_merchant_delete_template ("get-templates-empty", - merchant_url, - "t1", - MHD_HTTP_NOT_FOUND), + merchant_url, + "t1", + MHD_HTTP_NOT_FOUND), TALER_TESTING_cmd_merchant_delete_template ("get-templates-empty", - merchant_url, - "template-1", - MHD_HTTP_NO_CONTENT), + merchant_url, + "template-1", + MHD_HTTP_NO_CONTENT), + TALER_TESTING_cmd_merchant_post_using_templates ( + "post-templates-t1-deleted", + "post-templates-t1", + merchant_url, + "summary-1", + "EUR:5", + MHD_HTTP_NOT_FOUND), TALER_TESTING_cmd_end () - }; + }; - struct TALER_TESTING_Command webhooks[] = { + struct TALER_TESTING_Command webhooks[] = { TALER_TESTING_cmd_merchant_get_webhooks ("get-webhooks-empty", - merchant_url, - MHD_HTTP_OK, - NULL), + merchant_url, + MHD_HTTP_OK, + NULL), TALER_TESTING_cmd_merchant_post_webhooks ("post-webhooks-w1", merchant_url, "webhook-1", @@ -1439,31 +1493,8 @@ run (void *cls, "webhook-1", MHD_HTTP_NO_CONTENT), TALER_TESTING_cmd_end () - }; + }; - struct TALER_TESTING_Command using_templates[] = { - TALER_TESTING_cmd_merchant_post_using_templates ("post-templates-t1", - merchant_url, - "template-1", - "EUR:10", - MHD_HTTP_NO_CONTENT), - TALER_TESTING_cmd_merchant_post_using_templates ("post-templates-t1-idem", - merchant_url, - "template-1", - "EUR:10", - MHD_HTTP_NO_CONTENT), - TALER_TESTING_cmd_merchant_post_using_templates ("post-templates-t1-non-idem", - merchant_url, - "template-1", - "EUR:5", - MHD_HTTP_CONFLICT), - TALER_TESTING_cmd_merchant_post_using_templates ("post-templates-t2", - merchant_url, - "template-2", - "EUR:10", - MHD_HTTP_NO_CONTENT), - TALER_TESTING_cmd_end () - }; struct TALER_TESTING_Command commands[] = { /* general setup */ @@ -1819,8 +1850,6 @@ run (void *cls, templates), TALER_TESTING_cmd_batch ("webhooks", webhooks), - TALER_TESTING_cmd_batch ("using_templates", - using_templates), /** * End the suite. */ diff --git a/src/testing/testing_api_cmd_get_template.c b/src/testing/testing_api_cmd_get_template.c index 4e5580da..2f0f882a 100644 --- a/src/testing/testing_api_cmd_get_template.c +++ b/src/testing/testing_api_cmd_get_template.c @@ -78,10 +78,10 @@ struct GetTemplateState */ static void get_template_cb (void *cls, - const struct TALER_MERCHANT_HttpResponse *hr, - const char *template_description, - const char *image, - const json_t *template_contract) + const struct TALER_MERCHANT_HttpResponse *hr, + const char *template_description, + const char *image, + const json_t *template_contract) { struct GetTemplateState *gis = cls; const struct TALER_TESTING_Command *template_cmd; @@ -108,7 +108,7 @@ get_template_cb (void *cls, gis->template_reference); if (GNUNET_OK != TALER_TESTING_get_trait_template_description (template_cmd, - &expected_description)) + &expected_description)) TALER_TESTING_interpreter_fail (gis->is); if (0 != strcmp (template_description, *expected_description)) @@ -124,10 +124,13 @@ get_template_cb (void *cls, if (GNUNET_OK != TALER_TESTING_get_trait_template_image (template_cmd, - &expected_image)) + &expected_image)) TALER_TESTING_interpreter_fail (gis->is); - if (0 != strcmp (image, - *expected_image)) + if ( ( (NULL == image) && (NULL != *expected_image)) || + ( (NULL != image) && (NULL == *expected_image)) || + ( (NULL != image) && + (0 != strcmp (image, + *expected_image)) ) ) { GNUNET_log (GNUNET_ERROR_TYPE_ERROR, "Template image does not match\n"); @@ -174,17 +177,17 @@ get_template_cb (void *cls, */ static void get_template_run (void *cls, - const struct TALER_TESTING_Command *cmd, - struct TALER_TESTING_Interpreter *is) + const struct TALER_TESTING_Command *cmd, + struct TALER_TESTING_Interpreter *is) { struct GetTemplateState *gis = cls; gis->is = is; gis->igh = TALER_MERCHANT_template_get (is->ctx, - gis->merchant_url, - gis->template_id, - &get_template_cb, - gis); + gis->merchant_url, + gis->template_id, + &get_template_cb, + gis); GNUNET_assert (NULL != gis->igh); } @@ -198,7 +201,7 @@ get_template_run (void *cls, */ static void get_template_cleanup (void *cls, - const struct TALER_TESTING_Command *cmd) + const struct TALER_TESTING_Command *cmd) { struct GetTemplateState *gis = cls; @@ -214,10 +217,10 @@ get_template_cleanup (void *cls, struct TALER_TESTING_Command TALER_TESTING_cmd_merchant_get_template (const char *label, - const char *merchant_url, - const char *template_id, - unsigned int http_status, - const char *template_reference) + const char *merchant_url, + const char *template_id, + unsigned int http_status, + const char *template_reference) { struct GetTemplateState *gis; diff --git a/src/testing/testing_api_cmd_post_templates.c b/src/testing/testing_api_cmd_post_templates.c index 3708a467..c80e00cf 100644 --- a/src/testing/testing_api_cmd_post_templates.c +++ b/src/testing/testing_api_cmd_post_templates.c @@ -85,7 +85,7 @@ struct PostTemplatesState */ static void post_templates_cb (void *cls, - const struct TALER_MERCHANT_HttpResponse *hr) + const struct TALER_MERCHANT_HttpResponse *hr) { struct PostTemplatesState *tis = cls; @@ -130,20 +130,20 @@ post_templates_cb (void *cls, */ static void post_templates_run (void *cls, - const struct TALER_TESTING_Command *cmd, - struct TALER_TESTING_Interpreter *is) + const struct TALER_TESTING_Command *cmd, + struct TALER_TESTING_Interpreter *is) { struct PostTemplatesState *tis = cls; tis->is = is; tis->iph = TALER_MERCHANT_templates_post (is->ctx, - tis->merchant_url, - tis->template_id, - tis->template_description, - tis->image, - tis->template_contract, - &post_templates_cb, - tis); + tis->merchant_url, + tis->template_id, + tis->template_description, + tis->image, + tis->template_contract, + &post_templates_cb, + tis); GNUNET_assert (NULL != tis->iph); } @@ -158,11 +158,11 @@ post_templates_run (void *cls, * @param index index number of the object to extract. * @return #GNUNET_OK on success */ -static int +static enum GNUNET_GenericReturnValue post_templates_traits (void *cls, - const void **ret, - const char *trait, - unsigned int index) + const void **ret, + const char *trait, + unsigned int index) { struct PostTemplatesState *pts = cls; struct TALER_TESTING_Trait traits[] = { @@ -190,7 +190,7 @@ post_templates_traits (void *cls, */ static void post_templates_cleanup (void *cls, - const struct TALER_TESTING_Command *cmd) + const struct TALER_TESTING_Command *cmd) { struct PostTemplatesState *tis = cls; @@ -226,7 +226,7 @@ TALER_TESTING_cmd_merchant_post_templates2 ( tis->template_id = template_id; tis->http_status = http_status; tis->template_description = template_description; - tis->image = GNUNET_strdup (image); + tis->image = (NULL == image) ? NULL : GNUNET_strdup (image); tis->template_contract = template_contract; { struct TALER_TESTING_Command cmd = { @@ -244,17 +244,17 @@ TALER_TESTING_cmd_merchant_post_templates2 ( struct TALER_TESTING_Command TALER_TESTING_cmd_merchant_post_templates (const char *label, - const char *merchant_url, - const char *template_id, - const char *template_description, - unsigned int http_status) + const char *merchant_url, + const char *template_id, + const char *template_description, + unsigned int http_status) { return TALER_TESTING_cmd_merchant_post_templates2 ( label, merchant_url, template_id, template_description, - "", + NULL, json_pack ("{s:s}", "merchant", "Pay"), http_status); } diff --git a/src/testing/testing_api_cmd_post_using_templates.c b/src/testing/testing_api_cmd_post_using_templates.c index 6b97aa36..026d460a 100644 --- a/src/testing/testing_api_cmd_post_using_templates.c +++ b/src/testing/testing_api_cmd_post_using_templates.c @@ -1,6 +1,6 @@ /* This file is part of TALER - Copyright (C) 2020 Taler Systems SA + Copyright (C) 2022 Taler Systems SA TALER is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as @@ -59,6 +59,11 @@ struct PostUsingTemplatesState struct TALER_Amount amount; /** + * Label of a command that created the template we should use. + */ + const char *template_ref; + + /** * Expected HTTP response code. */ unsigned int http_status; @@ -91,14 +96,11 @@ post_using_templates_cb (void *cls, } switch (hr->http_status) { - case MHD_HTTP_NO_CONTENT: - break; - case MHD_HTTP_NOT_ACCEPTABLE: + case MHD_HTTP_OK: + // FIXME: check reply! break; case MHD_HTTP_CONFLICT: break; - case MHD_HTTP_FORBIDDEN: - break; case MHD_HTTP_NOT_FOUND: break; default: @@ -106,10 +108,12 @@ post_using_templates_cb (void *cls, GNUNET_log (GNUNET_ERROR_TYPE_WARNING, "Unhandled HTTP status %u for POST /templates/$ID.\n", hr->http_status); + break; } TALER_TESTING_interpreter_next (tis->is); } + /** * Run the "POST /using-templates" CMD. * @@ -124,62 +128,30 @@ post_using_templates_run (void *cls, struct TALER_TESTING_Interpreter *is) { struct PostUsingTemplatesState *tis = cls; - const char *template_id; + const struct TALER_TESTING_Command *ref; + const char **template_id; tis->is = is; - - const json_t *contract_terms; - const char *error_name; - unsigned int error_line; - const char **proposal_reference; - - if (NULL== cmd) + ref = TALER_TESTING_interpreter_lookup_command (is, + tis->template_ref); + if (GNUNET_OK != + TALER_TESTING_get_trait_template_id (ref, + &template_id)) TALER_TESTING_FAIL (is); - { - - if (GNUNET_OK != - TALER_TESTING_get_trait_contract_terms (cmd, - &contract_terms)) - TALER_TESTING_FAIL (is); - { - /* Get information that needs to be put verbatim in the - * deposit permission */ - struct GNUNET_JSON_Specification spec[] = { - GNUNET_JSON_spec_string ("template_id", - &template_id), - GNUNET_JSON_spec_end () - }; - - if (GNUNET_OK != - GNUNET_JSON_parse (contract_terms, - spec, - &error_name, - &error_line)) - { - char *js; - js = json_dumps (contract_terms, - JSON_INDENT (1)); - GNUNET_log (GNUNET_ERROR_TYPE_ERROR, - "Parser failed on %s:%u for input `%s'\n", - error_name, - error_line, - js); - free (js); - TALER_TESTING_FAIL (is); - } - } - } - - tis->iph = TALER_MERCHANT_using_templates_post (is->ctx, - tis->merchant_url, - template_id, - tis->summary, - &tis->amount, - &post_using_templates_cb, - tis); + tis->iph = TALER_MERCHANT_using_templates_post ( + is->ctx, + tis->merchant_url, + *template_id, + tis->summary, + TALER_amount_is_valid (&tis->amount) + ? &tis->amount + : NULL, + &post_using_templates_cb, + tis); GNUNET_assert (NULL != tis->iph); } + /** * Offers information from the POST /using-templates CMD state to other * commands. @@ -190,7 +162,7 @@ post_using_templates_run (void *cls, * @param index index number of the object to extract. * @return #GNUNET_OK on success */ -static int +static enum GNUNET_GenericReturnValue post_using_templates_traits (void *cls, const void **ret, const char *trait, @@ -198,11 +170,10 @@ post_using_templates_traits (void *cls, { struct PostUsingTemplatesState *pts = cls; struct TALER_TESTING_Trait traits[] = { - TALER_TESTING_make_trait_summary (&pts->summary), - TALER_TESTING_make_trait_amount (&pts->amount), TALER_TESTING_trait_end (), }; + (void) pts; return TALER_TESTING_get_trait (traits, ret, trait, @@ -234,8 +205,9 @@ post_using_templates_cleanup (void *cls, struct TALER_TESTING_Command -TALER_TESTING_cmd_merchant_post_using_templates2 ( +TALER_TESTING_cmd_merchant_post_using_templates ( const char *label, + const char *template_ref, const char *merchant_url, const char *summary, const char *amount, @@ -244,13 +216,14 @@ TALER_TESTING_cmd_merchant_post_using_templates2 ( struct PostUsingTemplatesState *tis; tis = GNUNET_new (struct PostUsingTemplatesState); + tis->template_ref = template_ref; tis->merchant_url = merchant_url; tis->http_status = http_status; tis->summary = summary; - GNUNET_assert (GNUNET_OK == - TALER_string_to_amount (amount, - &tis->amount)); - + if (NULL != amount) + GNUNET_assert (GNUNET_OK == + TALER_string_to_amount (amount, + &tis->amount)); { struct TALER_TESTING_Command cmd = { .cls = tis, @@ -264,20 +237,5 @@ TALER_TESTING_cmd_merchant_post_using_templates2 ( } } -struct TALER_TESTING_Command -TALER_TESTING_cmd_merchant_post_using_templates (const char *label, - const char *merchant_url, - const char *summary, - const char *amount, - unsigned int http_status) -{ - return TALER_TESTING_cmd_merchant_post_using_templates2 ( - label, - merchant_url, - summary, - amount, - http_status); -} - /* end of testing_api_cmd_post_using_templates.c */ |