<div dir="ltr"><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">Hi Aleksander,</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"><br></div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">thanks for the quick reply. My comments are below, even if I mostly agree with your observations</div><div class="gmail_extra"><br><div class="gmail_quote">On 7 March 2016 at 16:15, Aleksander Morgado <span dir="ltr"><<a href="mailto:aleksander@aleksander.es" target="_blank">aleksander@aleksander.es</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Hey,<br>
<br>
>From now on, please implement all async calls using the newer GTask,<br>
instead of GSimpleAsyncResult. No need to rework this patch for that,<br>
just take it into consideration for future patches :)<br></blockquote><div><br></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif;display:inline">I will</div></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif;display:inline"></div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
See comments below.<br>
<div><div class="h5"><br>
On Mon, Mar 7, 2016 at 3:04 PM, <<a href="mailto:c.lobrano@gmail.com">c.lobrano@gmail.com</a>> wrote:<br>
> From: Carlo Lobrano <<a href="mailto:c.lobrano@gmail.com">c.lobrano@gmail.com</a>><br>
><br>
> - Add new async virtual method load_current_storages to<br>
> MMIfaceModemMessaging<br>
> - Add logic of load_current_storages to MMBroadbandModem<br>
> - Add step "LOAD_CURRENT_STORAGES" in MMIfaceModemMessaging<br>
> initialization in order to load and store current SMS<br>
> storages for mem1 and mem2.<br>
> - Add usage of current sms storage value for mem1 in place<br>
> of an empty string parameter when the command AT+CPMS<br>
> is used.<br>
> ---<br>
> src/mm-broadband-modem.c | 89 +++++++++++++++++++++++++++++++++++++++++-<br>
> src/mm-iface-modem-messaging.c | 37 ++++++++++++++++++<br>
> src/mm-iface-modem-messaging.h | 11 ++++++<br>
> src/mm-modem-helpers.c | 77 ++++++++++++++++++++++++++++++++++++<br>
> src/mm-modem-helpers.h | 10 +++++<br>
> src/tests/test-modem-helpers.c | 36 +++++++++++++++++<br>
> 6 files changed, 258 insertions(+), 2 deletions(-)<br>
><br>
> diff --git a/src/mm-broadband-modem.c b/src/mm-broadband-modem.c<br>
> index 6fc0663..08c8f13 100644<br>
> --- a/src/mm-broadband-modem.c<br>
> +++ b/src/mm-broadband-modem.c<br>
> @@ -5242,6 +5242,82 @@ modem_messaging_load_supported_storages (MMIfaceModemMessaging *self,<br>
> }<br>
><br>
> /*****************************************************************************/<br>
> +/* Load current SMS storages (Messaging interface) */<br>
> +<br>
> +static gboolean<br>
> +modem_messaging_load_current_storages_finish (MMIfaceModemMessaging *_self,<br>
> + GAsyncResult *res,<br>
> + GError **error)<br>
> +{<br>
> + if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))<br>
> + return FALSE;<br>
> +<br>
> + return TRUE;<br>
<br>
</div></div>Just "return !g_simple_async_result_propagate_error (...);"<br>
<div><div class="h5"><br>
> +}<br>
> +<br>
> +static void<br>
> +cpms_query_ready (MMBroadbandModem *self,<br>
> + GAsyncResult *res,<br>
> + GSimpleAsyncResult *simple)<br>
> +{<br>
> + const gchar *response;<br>
> + GError *error = NULL;<br>
> + MMSmsStorage mem1;<br>
> + MMSmsStorage mem2;<br>
> +<br>
> + response = mm_base_modem_at_command_finish (MM_BASE_MODEM(self), res, &error);<br>
> + if (error) {<br>
> + g_simple_async_result_take_error (simple, error);<br>
> + g_simple_async_result_complete (simple);<br>
> + g_object_unref (simple);<br>
> + return;<br>
> + }<br>
> +<br>
> + /* Parse reply */<br>
> + if (!mm_3gpp_parse_cpms_query_response (response,<br>
> + &mem1,<br>
> + &mem2,<br>
> + &error)) {<br>
> + g_simple_async_result_take_error (simple, error);<br>
> + } else {<br>
> + self->priv->current_sms_mem1_storage = mem1;<br>
> + self->priv->current_sms_mem2_storage = mem2;<br>
> +<br>
> + mm_dbg ("Current storages loaded:");<br>
> + mm_dbg (" mem1 (list/read/delete) storages: '%s'",<br>
> + mm_common_build_sms_storages_string(&mem1, 1));<br>
> + mm_dbg (" mem2 (write/send) storages: '%s'",<br>
> + mm_common_build_sms_storages_string(&mem2, 1));<br>
> + }<br>
> +<br>
> + g_simple_async_result_complete (simple);<br>
> + g_object_unref (simple);<br>
> +}<br>
> +<br>
> +static void<br>
> +modem_messaging_load_current_storages (MMIfaceModemMessaging *self,<br>
> + GAsyncReadyCallback callback,<br>
> + gpointer user_data)<br>
> +{<br>
> + GSimpleAsyncResult *result;<br>
> +<br>
> + result = g_simple_async_result_new (G_OBJECT (self),<br>
> + callback,<br>
> + user_data,<br>
> + modem_messaging_load_current_storages);<br>
> +<br>
> + /* Check support storages */<br>
> + mm_base_modem_at_command (MM_BASE_MODEM (self),<br>
> + "+CPMS?",<br>
> + 3,<br>
> + TRUE,<br>
> + (GAsyncReadyCallback)cpms_query_ready,<br>
> + result);<br>
> +}<br>
> +<br>
<br>
</div></div>Too many empty lines here, just one enough.<br>
<span class=""><br>
> +<br>
> +<br>
> +/*****************************************************************************/<br>
> /* Lock/unlock SMS storage (Messaging interface implementation helper)<br>
> *<br>
> * The basic commands to work with SMS storages play with AT+CPMS and three<br>
> @@ -5373,8 +5449,9 @@ mm_broadband_modem_lock_sms_storages (MMBroadbandModem *self,<br>
> ctx->previous_mem1 = self->priv->current_sms_mem1_storage;<br>
> self->priv->mem1_storage_locked = TRUE;<br>
> self->priv->current_sms_mem1_storage = mem1;<br>
> - mem1_str = g_ascii_strup (mm_sms_storage_get_string (self->priv->current_sms_mem1_storage), -1);<br>
> }<br>
> + /* We always provide a non empty string parameter as mem1 */<br>
> + mem1_str = g_ascii_strup (mm_sms_storage_get_string (self->priv->current_sms_mem1_storage), -1);<br>
><br>
<br>
</span>This is a bit confusing actually. The fact that we're passing the mem1<br>
value when e.g. trying to lock mem2 doesn't mean that we can be<br>
changing the mem1 while some other async logic got it locked before. I<br>
think your code is ok, but I spent 30 mins convinced that it wasn't,<br>
I'm not 100% sure yet :) The key point is that If mem1 is locked for<br>
an operation, no other operation that wants to lock mem1 can be run<br>
(ok); but we can still run operations that want to lock mem2 only (and<br>
in that case we're just re-sending the already locked mem1 value). Can<br>
you try to explain that in the comment?<br>
<span class=""><br></span></blockquote><div><br></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">I'm actually considering now the fact that I need a mem1_str only when mem2_str is not NULL.</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"><br></div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">I could keep the "if (mem1 != MM_SMS_STORAGE_UNKNOWN)" as it was before, and do something like this</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"><br></div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">if (mem2 != MM_SMS_STORAGE_UNKNOWN) {</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"> ...</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"> mem2_str = g_ascii_strup (mm_sms_storage_get_string (self->priv->current_sms_mem2_storage), -1);</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"><br></div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"> if (mem1 == MM_SMS_STORAGE_UNKNOWN) {</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"> /* Verbose explanation */</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"> mem1_str = g_ascii_strup(mm_sms_storage_get_string (self->priv->current_sms_mem1_storage), -1);</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif"> }</div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">}</div><br></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">This way the change will effect only the cases when mem2 only is to be locked and the verbose explanation should be more clear to understand.</div><br></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">What do you think?</div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><span class="">
<br>
> if (mem2 != MM_SMS_STORAGE_UNKNOWN) {<br>
> ctx->mem2_locked = TRUE;<br>
> @@ -5446,6 +5523,7 @@ modem_messaging_set_default_storage (MMIfaceModemMessaging *_self,<br>
> MMBroadbandModem *self = MM_BROADBAND_MODEM (_self);<br>
> gchar *cmd;<br>
> GSimpleAsyncResult *result;<br>
> + gchar *mem1_str;<br>
> gchar *mem_str;<br>
><br>
> result = g_simple_async_result_new (G_OBJECT (self),<br>
> @@ -5456,8 +5534,13 @@ modem_messaging_set_default_storage (MMIfaceModemMessaging *_self,<br>
> /* Set defaults as current */<br>
> self->priv->current_sms_mem2_storage = storage;<br>
><br>
> + /* Some modems do no support empty string as parameter.<br>
> + * Here we keep the value or Memr as the one get with<br>
> + * load_current_storages step */<br>
<br>
</span>Not sure I undestand the last sentence.<br></blockquote><div><br></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif;display:inline">I'll rephrase that. I just wanted to say that we will use the current value of mem1.</div></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif;display:inline"></div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<span class=""><br>
> + mem1_str = g_ascii_strup (mm_sms_storage_get_string (self->priv->current_sms_mem1_storage), -1);<br>
> +<br>
<br>
</span>Oh, hum... I thought this was going to be telit-only.<br>
<br>
Given that the new async method you wrote is optional (e.g. subclasses<br>
can set it as NULL, and we also don't care if it fails), we still have<br>
the possibility of seeing UNKNOWN in "current_sms_mem1_storage". I<br>
would change the logic so that, if we see UNKNOWN in mem1, we use the<br>
old method of providing the empty string.<br>
<div><div class="h5"><br>
> mem_str = g_ascii_strup (mm_sms_storage_get_string (storage), -1);<br>
> - cmd = g_strdup_printf ("+CPMS=\"\",\"%s\",\"%s\"", mem_str, mem_str);<br>
> + cmd = g_strdup_printf ("+CPMS=\"%s\",\"%s\",\"%s\"", mem1_str, mem_str, mem_str);<br>
> mm_base_modem_at_command (MM_BASE_MODEM (self),<br>
> cmd,<br>
> 3,<br>
> @@ -10390,6 +10473,8 @@ iface_modem_messaging_init (MMIfaceModemMessaging *iface)<br>
> iface->cleanup_unsolicited_events = modem_messaging_cleanup_unsolicited_events;<br>
> iface->cleanup_unsolicited_events_finish = modem_messaging_setup_cleanup_unsolicited_events_finish;<br>
> iface->create_sms = modem_messaging_create_sms;<br>
> + iface->load_current_storages = modem_messaging_load_current_storages;<br>
> + iface->load_current_storages_finish = modem_messaging_load_current_storages_finish;<br>
> }<br>
><br>
> static void<br>
> diff --git a/src/mm-iface-modem-messaging.c b/src/mm-iface-modem-messaging.c<br>
> index d2ef6e8..5058569 100644<br>
> --- a/src/mm-iface-modem-messaging.c<br>
> +++ b/src/mm-iface-modem-messaging.c<br>
> @@ -1057,6 +1057,7 @@ typedef enum {<br>
> INITIALIZATION_STEP_CHECK_SUPPORT,<br>
> INITIALIZATION_STEP_FAIL_IF_UNSUPPORTED,<br>
> INITIALIZATION_STEP_LOAD_SUPPORTED_STORAGES,<br>
> + INITIALIZATION_STEP_LOAD_CURRENT_STORAGES,<br>
> INITIALIZATION_STEP_LAST<br>
> } InitializationStep;<br>
><br>
> @@ -1213,6 +1214,30 @@ check_support_ready (MMIfaceModemMessaging *self,<br>
> }<br>
><br>
> static void<br>
> +load_current_storages_ready (MMIfaceModemMessaging *self,<br>
> + GAsyncResult *res,<br>
> + InitializationContext *ctx)<br>
> +{<br>
> + StorageContext *storage_ctx;<br>
> + GError *error = NULL;<br>
> +<br>
> + storage_ctx = get_storage_context (self);<br>
> + if (!MM_IFACE_MODEM_MESSAGING_GET_INTERFACE (self)->load_current_storages_finish (<br>
> + self,<br>
> + res,<br>
> + &error)) {<br>
> + mm_dbg ("Couldn't load current storages: '%s'", error->message);<br>
> + g_error_free (error);<br>
> + } else {<br>
> + mm_dbg ("Current storages loaded");<br>
> + }<br>
> +<br>
> + /* Go on to next step */<br>
> + ctx->step++;<br>
> + interface_initialization_step (ctx);<br>
> +}<br>
> +<br>
> +static void<br>
> interface_initialization_step (InitializationContext *ctx)<br>
> {<br>
> /* Don't run new steps if we're cancelled */<br>
> @@ -1284,6 +1309,18 @@ interface_initialization_step (InitializationContext *ctx)<br>
> /* Fall down to next step */<br>
> ctx->step++;<br>
><br>
> + case INITIALIZATION_STEP_LOAD_CURRENT_STORAGES:<br>
> + if (MM_IFACE_MODEM_MESSAGING_GET_INTERFACE (ctx->self)->load_current_storages &&<br>
> + MM_IFACE_MODEM_MESSAGING_GET_INTERFACE (ctx->self)->load_current_storages_finish) {<br>
> + MM_IFACE_MODEM_MESSAGING_GET_INTERFACE (ctx->self)->load_current_storages (<br>
> + ctx->self,<br>
> + (GAsyncReadyCallback)load_current_storages_ready,<br>
> + ctx);<br>
> + return;<br>
> + }<br>
> + /* Fall down to next step */<br>
> + ctx->step++;<br>
> +<br>
> case INITIALIZATION_STEP_LAST:<br>
> /* We are done without errors! */<br>
><br>
> diff --git a/src/mm-iface-modem-messaging.h b/src/mm-iface-modem-messaging.h<br>
> index c27e100..0a289df 100644<br>
> --- a/src/mm-iface-modem-messaging.h<br>
> +++ b/src/mm-iface-modem-messaging.h<br>
> @@ -62,6 +62,17 @@ struct _MMIfaceModemMessaging {<br>
> GArray **mem2,<br>
> GArray **mem3,<br>
> GError **error);<br>
> + /* Load current storages for...<br>
> + * mem1: listing/reading/deleting<br>
> + * mem2: writing/sending<br>
> + * mem3: receiving<br>
> + */<br>
> + void (* load_current_storages) (MMIfaceModemMessaging *self,<br>
> + GAsyncReadyCallback callback,<br>
> + gpointer user_data);<br>
> + gboolean (*load_current_storages_finish) (MMIfaceModemMessaging *self,<br>
> + GAsyncResult *res,<br>
> + GError **error);<br>
><br>
<br>
</div></div>Humm.. given that we're not returning the storage values for<br>
mem1/mem2, maybe we should rename the method to<br>
"init_current_storages" or something like that. The key point here is<br>
to make it clear that this is not a async method to load something<br>
that we're exposing in the DBus API, but an async method which does<br>
some internal initialization in the actual implementation. What do you<br>
think?<br></blockquote><div><br></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif;display:inline">init_current_storages it's fine for me.</div></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif;display:inline"></div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<span class=""><br>
<br>
> /* Set default storage (async) */<br>
> void (* set_default_storage) (MMIfaceModemMessaging *self,<br>
> diff --git a/src/mm-modem-helpers.c b/src/mm-modem-helpers.c<br>
> index 58394ee..3c64263 100644<br>
> --- a/src/mm-modem-helpers.c<br>
> +++ b/src/mm-modem-helpers.c<br>
> @@ -1507,6 +1507,83 @@ mm_3gpp_parse_cpms_test_response (const gchar *reply,<br>
> return FALSE;<br>
> }<br>
><br>
> +/**********************************************************************<br>
> + * AT+CPMS?<br>
> + * +CPMS: <memr>,<usedr>,<totalr>,<memw>,<usedw>,<totalw>, <mems>,<useds>,<totals><br>
> + */<br>
> +<br>
> +#define CPMS_QUERY_REGEX "\\+CPMS:\\s*\"(?P<memr>.*)\",[0-9]+,[0-9]+,\"(?P<memw>.*)\",[0-9]+,[0-9]+,\"(?P<mems>.*)\",[0-9]+,[0-9]"<br>
> +<br>
<br>
</span>Named fields in regex, not sure if I love it or hate it :)<br></blockquote><div><br></div><div><div class="gmail_default" style="font-family:arial,helvetica,sans-serif">I think it's a good way to express what one expects to get from the regex, but that's just an opinion :)</div></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div class="h5"><br>
> +gboolean<br>
> +mm_3gpp_parse_cpms_query_response (const gchar *reply,<br>
> + MMSmsStorage *memr,<br>
> + MMSmsStorage *memw,<br>
> + GError **error)<br>
> +{<br>
> + GRegex *r = NULL;<br>
> + gboolean ret = FALSE;<br>
> + GMatchInfo *match_info = NULL;<br>
> +<br>
> + r = g_regex_new (CPMS_QUERY_REGEX, G_REGEX_RAW, 0, NULL);<br>
> +<br>
> + g_assert(r);<br>
> +<br>
> + if (!g_regex_match (r, reply, 0, &match_info)) {<br>
> + g_set_error (error, MM_CORE_ERROR, MM_CORE_ERROR_FAILED,<br>
> + "Could not parse CPMS query reponse '%s'", reply);<br>
> + goto end;<br>
> + }<br>
> +<br>
> + if (!g_match_info_matches(match_info)) {<br>
> + g_set_error (error, MM_CORE_ERROR, MM_CORE_ERROR_FAILED,<br>
> + "Could not find matches in CPMS query reply '%s'", reply);<br>
> + goto end;<br>
> + }<br>
> +<br>
> + if (!mm_3gpp_get_cpms_storage_match (match_info, "memr", memr, error)) {<br>
> + goto end;<br>
> + }<br>
> +<br>
> + if (!mm_3gpp_get_cpms_storage_match (match_info, "memw", memw, error)) {<br>
> + goto end;<br>
> + }<br>
> +<br>
> + ret = TRUE;<br>
> +<br>
> +end:<br>
> + if (r != NULL)<br>
> + g_regex_unref (r);<br>
> +<br>
> + if (match_info != NULL)<br>
> + g_match_info_free (match_info);<br>
> +<br>
> + return ret;<br>
> +}<br>
> +<br>
> +gboolean<br>
> +mm_3gpp_get_cpms_storage_match (GMatchInfo *match_info,<br>
> + const gchar *match_name,<br>
> + MMSmsStorage *storage,<br>
> + GError **error)<br>
> +{<br>
> + gboolean ret = TRUE;<br>
> + gchar *str = NULL;<br>
> +<br>
> + str = g_match_info_fetch_named(match_info, match_name);<br>
> + if (str == NULL || str[0] == '\0') {<br>
> + g_set_error (error, MM_CORE_ERROR, MM_CORE_ERROR_FAILED,<br>
> + "Could not find '%s' from CPMS reply", match_name);<br>
> + ret = FALSE;<br>
> + } else {<br>
> + *storage = storage_from_str (str);<br>
> + }<br>
> +<br>
> + if (str != NULL)<br>
> + g_free (str);<br>
<br>
</div></div>No need the if(); g_free(NULL) is perfectly valid.<br>
<div><div class="h5"><br>
> +<br>
> + return ret;<br>
> +}<br>
> +<br>
> /*************************************************************************/<br>
><br>
> gboolean<br>
> diff --git a/src/mm-modem-helpers.h b/src/mm-modem-helpers.h<br>
> index 975a493..476b315 100644<br>
> --- a/src/mm-modem-helpers.h<br>
> +++ b/src/mm-modem-helpers.h<br>
> @@ -158,6 +158,16 @@ gboolean mm_3gpp_parse_cpms_test_response (const gchar *reply,<br>
> GArray **mem2,<br>
> GArray **mem3);<br>
><br>
> +/* AT+CPMS? (Current SMS storage) response parser */<br>
> +gboolean mm_3gpp_parse_cpms_query_response (const gchar *reply,<br>
> + MMSmsStorage *mem1,<br>
> + MMSmsStorage *mem2,<br>
> + GError** error);<br>
> +gboolean mm_3gpp_get_cpms_storage_match (GMatchInfo *match_info,<br>
> + const gchar *match_name,<br>
> + MMSmsStorage *storage,<br>
> + GError **error);<br>
> +<br>
> /* AT+CSCS=? (Supported charsets) response parser */<br>
> gboolean mm_3gpp_parse_cscs_test_response (const gchar *reply,<br>
> MMModemCharset *out_charsets);<br>
> diff --git a/src/tests/test-modem-helpers.c b/src/tests/test-modem-helpers.c<br>
> index db84f01..837317f 100644<br>
> --- a/src/tests/test-modem-helpers.c<br>
> +++ b/src/tests/test-modem-helpers.c<br>
> @@ -2070,6 +2070,41 @@ test_cpms_response_empty_fields (void *f, gpointer d)<br>
> g_array_unref (mem3);<br>
> }<br>
><br>
> +typedef struct {<br>
> + const gchar *query;<br>
> + MMSmsStorage mem1_want;<br>
> + MMSmsStorage mem2_want;<br>
> +} CpmsQueryTest;<br>
> +<br>
> +CpmsQueryTest cpms_query_test[] = {<br>
> + {"+CPMS: \"ME\",1,100,\"MT\",5,100,\"TA\",1,100", 2, 3},<br>
> + {"+CPMS: \"SM\",100,100,\"SR\",5,10,\"TA\",1,100", 1, 4},<br>
> + {"+CPMS: \"XX\",100,100,\"BM\",5,10,\"TA\",1,100", 0, 5},<br>
> + {"+CPMS: \"XX\",100,100,\"YY\",5,10,\"TA\",1,100", 0, 0},<br>
> + {NULL, 0, 0}<br>
> +};<br>
> +<br>
> +static void<br>
> +test_cpms_query_response (void *f, gpointer d) {<br>
> + MMSmsStorage mem1;<br>
> + MMSmsStorage mem2;<br>
> + gboolean ret;<br>
> + GError *error;<br>
<br>
</div></div>GError must always be initialized to NULL before using it:<br>
GError *error = NULL;<br>
<span class=""><br>
> + int i;<br>
> +<br>
> + for (i = 0; cpms_query_test[i].query != NULL; i++){<br>
> + ret = mm_3gpp_parse_cpms_query_response (cpms_query_test[i].query,<br>
> + &mem1,<br>
> + &mem2,<br>
> + &error);<br>
> +<br>
<br>
</span>No need for this whiteline here.<br>
<br>
> + g_assert(ret);<br>
<br>
I'd include:<br>
g_assert_no_error (error);<br>
<span class=""><br>
> + g_assert_cmpuint (cpms_query_test[i].mem1_want, ==, mem1);<br>
> + g_assert_cmpuint (cpms_query_test[i].mem2_want, ==, mem2);<br>
> + }<br>
> +<br>
<br>
</span>No need for this whiteline here.<br>
<span class=""><br>
> +}<br>
> +<br>
> /*****************************************************************************/<br>
> /* Test CNUM responses */<br>
><br>
> @@ -2821,6 +2856,7 @@ int main (int argc, char **argv)<br>
> g_test_suite_add (suite, TESTCASE (test_cpms_response_mixed, NULL));<br>
> g_test_suite_add (suite, TESTCASE (test_cpms_response_mixed_spaces, NULL));<br>
> g_test_suite_add (suite, TESTCASE (test_cpms_response_empty_fields, NULL));<br>
> + g_test_suite_add (suite, TESTCASE (test_cpms_query_response, NULL));<br>
><br>
> g_test_suite_add (suite, TESTCASE (test_cgdcont_test_response_single, NULL));<br>
> g_test_suite_add (suite, TESTCASE (test_cgdcont_test_response_multiple, NULL));<br>
> --<br>
> 2.1.4<br>
><br>
</span>> _______________________________________________<br>
> ModemManager-devel mailing list<br>
> <a href="mailto:ModemManager-devel@lists.freedesktop.org">ModemManager-devel@lists.freedesktop.org</a><br>
> <a href="https://lists.freedesktop.org/mailman/listinfo/modemmanager-devel" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/modemmanager-devel</a><br>
<span class=""><font color="#888888"><br>
<br>
<br>
--<br>
Aleksander<br>
<a href="https://aleksander.es" rel="noreferrer" target="_blank">https://aleksander.es</a><br>
</font></span></blockquote></div><br></div></div>