aboutsummaryrefslogtreecommitdiff
path: root/plugins/mbm/tests/test-modem-helpers-mbm.c
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/mbm/tests/test-modem-helpers-mbm.c')
-rw-r--r--plugins/mbm/tests/test-modem-helpers-mbm.c268
1 files changed, 0 insertions, 268 deletions
diff --git a/plugins/mbm/tests/test-modem-helpers-mbm.c b/plugins/mbm/tests/test-modem-helpers-mbm.c
deleted file mode 100644
index 4169140a..00000000
--- a/plugins/mbm/tests/test-modem-helpers-mbm.c
+++ /dev/null
@@ -1,268 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details:
- *
- * Copyright (C) 2013 Aleksander Morgado <aleksander@gnu.org>
- * Copyright (C) 2014 Dan Williams <dcbw@redhat.com>
- */
-
-#include <glib.h>
-#include <glib-object.h>
-#include <locale.h>
-#include <netinet/in.h>
-#include <arpa/inet.h>
-
-#include <ModemManager.h>
-#define _LIBMM_INSIDE_MM
-#include <libmm-glib.h>
-
-#include "mm-log-test.h"
-#include "mm-modem-helpers.h"
-#include "mm-modem-helpers-mbm.h"
-
-/*****************************************************************************/
-/* Test *E2IPCFG responses */
-
-typedef struct {
- const gchar *str;
-
- /* IPv4 */
- const gchar *ipv4_addr;
- const gchar *ipv4_gw;
- const gchar *ipv4_dns1;
- const gchar *ipv4_dns2;
-
- /* IPv6 */
- const gchar *ipv6_addr;
- const gchar *ipv6_dns1;
- const gchar *ipv6_dns2;
-} E2ipcfgTest;
-
-static const E2ipcfgTest tests[] = {
- { "*E2IPCFG: (1,\"46.157.32.246\")(2,\"46.157.32.243\")(3,\"193.213.112.4\")(3,\"130.67.15.198\")\r\n",
- "46.157.32.246", "46.157.32.243", "193.213.112.4", "130.67.15.198",
- NULL, NULL },
-
- { "*E2IPCFG: (1,\"fe80:0000:0000:0000:0000:0000:e537:1801\")(3,\"2001:4600:0004:0fff:0000:0000:0000:0054\")(3,\"2001:4600:0004:1fff:0000:0000:0000:0054\")\r\n",
- NULL, NULL, NULL, NULL,
- "fe80:0000:0000:0000:0000:0000:e537:1801", "2001:4600:0004:0fff:0000:0000:0000:0054", "2001:4600:0004:1fff:0000:0000:0000:0054" },
-
- { "*E2IPCFG: (1,\"fe80:0000:0000:0000:0000:0027:b7fe:9401\")(3,\"fd00:976a:0000:0000:0000:0000:0000:0009\")\r\n",
- NULL, NULL, NULL, NULL,
- "fe80:0000:0000:0000:0000:0027:b7fe:9401", "fd00:976a:0000:0000:0000:0000:0000:0009", NULL },
-
- { NULL }
-};
-
-static void
-test_e2ipcfg (void)
-{
- guint i;
-
- for (i = 0; tests[i].str; i++) {
- gboolean success;
- GError *error = NULL;
- MMBearerIpConfig *ipv4 = NULL;
- MMBearerIpConfig *ipv6 = NULL;
- const gchar **dns;
- guint dnslen;
-
- success = mm_mbm_parse_e2ipcfg_response (tests[i].str, &ipv4, &ipv6, &error);
- g_assert_no_error (error);
- g_assert (success);
-
- /* IPv4 */
- if (tests[i].ipv4_addr) {
- g_assert (ipv4);
- g_assert_cmpint (mm_bearer_ip_config_get_method (ipv4), ==, MM_BEARER_IP_METHOD_STATIC);
- g_assert_cmpstr (mm_bearer_ip_config_get_address (ipv4), ==, tests[i].ipv4_addr);
- g_assert_cmpint (mm_bearer_ip_config_get_prefix (ipv4), ==, 28);
- g_assert_cmpstr (mm_bearer_ip_config_get_gateway (ipv4), ==, tests[i].ipv4_gw);
-
- dns = mm_bearer_ip_config_get_dns (ipv4);
- g_assert (dns);
- dnslen = g_strv_length ((gchar **) dns);
- if (tests[i].ipv4_dns2 != NULL)
- g_assert_cmpint (dnslen, ==, 2);
- else
- g_assert_cmpint (dnslen, ==, 1);
- g_assert_cmpstr (dns[0], ==, tests[i].ipv4_dns1);
- g_assert_cmpstr (dns[1], ==, tests[i].ipv4_dns2);
- g_object_unref (ipv4);
- } else
- g_assert (ipv4 == NULL);
-
- /* IPv6 */
- if (tests[i].ipv6_addr) {
- struct in6_addr a6;
- g_assert (ipv6);
-
- g_assert_cmpstr (mm_bearer_ip_config_get_address (ipv6), ==, tests[i].ipv6_addr);
- g_assert_cmpint (mm_bearer_ip_config_get_prefix (ipv6), ==, 64);
-
- g_assert (inet_pton (AF_INET6, mm_bearer_ip_config_get_address (ipv6), &a6));
- if (IN6_IS_ADDR_LINKLOCAL (&a6))
- g_assert_cmpint (mm_bearer_ip_config_get_method (ipv6), ==, MM_BEARER_IP_METHOD_DHCP);
- else
- g_assert_cmpint (mm_bearer_ip_config_get_method (ipv6), ==, MM_BEARER_IP_METHOD_STATIC);
-
- dns = mm_bearer_ip_config_get_dns (ipv6);
- g_assert (dns);
- dnslen = g_strv_length ((gchar **) dns);
- if (tests[i].ipv6_dns2 != NULL)
- g_assert_cmpint (dnslen, ==, 2);
- else
- g_assert_cmpint (dnslen, ==, 1);
- g_assert_cmpstr (dns[0], ==, tests[i].ipv6_dns1);
- g_assert_cmpstr (dns[1], ==, tests[i].ipv6_dns2);
- g_object_unref (ipv6);
- } else
- g_assert (ipv6 == NULL);
- }
-}
-
-/*****************************************************************************/
-/* Test +CFUN test responses */
-
-#define MAX_MODES 32
-
-typedef struct {
- const gchar *str;
- guint32 expected_mask;
-} CfunTest;
-
-static const CfunTest cfun_tests[] = {
- {
- "+CFUN: (0,1,4-6),(1-0)\r\n",
- ((1 << MBM_NETWORK_MODE_OFFLINE) |
- (1 << MBM_NETWORK_MODE_ANY) |
- (1 << MBM_NETWORK_MODE_LOW_POWER) |
- (1 << MBM_NETWORK_MODE_2G) |
- (1 << MBM_NETWORK_MODE_3G))
- },
- {
- "+CFUN: (0,1,4-6)\r\n",
- ((1 << MBM_NETWORK_MODE_OFFLINE) |
- (1 << MBM_NETWORK_MODE_ANY) |
- (1 << MBM_NETWORK_MODE_LOW_POWER) |
- (1 << MBM_NETWORK_MODE_2G) |
- (1 << MBM_NETWORK_MODE_3G))
- },
- {
- "+CFUN: (0,1,4)\r\n",
- ((1 << MBM_NETWORK_MODE_OFFLINE) |
- (1 << MBM_NETWORK_MODE_ANY) |
- (1 << MBM_NETWORK_MODE_LOW_POWER))
- },
- {
- "+CFUN: (0,1)\r\n",
- ((1 << MBM_NETWORK_MODE_OFFLINE) |
- (1 << MBM_NETWORK_MODE_ANY))
- },
-};
-
-static void
-test_cfun_test (void)
-{
- guint i;
-
- for (i = 0; i < G_N_ELEMENTS (cfun_tests); i++) {
- guint32 mask;
- gboolean success;
- GError *error = NULL;
-
- success = mm_mbm_parse_cfun_test (cfun_tests[i].str, NULL, &mask, &error);
- g_assert_no_error (error);
- g_assert (success);
- g_assert_cmpuint (mask, ==, cfun_tests[i].expected_mask);
- }
-}
-
-/*****************************************************************************/
-
-typedef struct {
- const gchar *str;
- MMModemPowerState state;
-} CfunQueryPowerStateTest;
-
-static const CfunQueryPowerStateTest cfun_query_power_state_tests[] = {
- { "+CFUN: 0", MM_MODEM_POWER_STATE_OFF },
- { "+CFUN: 1", MM_MODEM_POWER_STATE_ON },
- { "+CFUN: 4", MM_MODEM_POWER_STATE_LOW },
- { "+CFUN: 5", MM_MODEM_POWER_STATE_ON },
- { "+CFUN: 6", MM_MODEM_POWER_STATE_ON },
-};
-
-static void
-test_cfun_query_power_state (void)
-{
- guint i;
-
- for (i = 0; i < G_N_ELEMENTS (cfun_query_power_state_tests); i++) {
- GError *error = NULL;
- gboolean success;
- MMModemPowerState state;
-
- success = mm_mbm_parse_cfun_query_power_state (cfun_query_power_state_tests[i].str, &state, &error);
- g_assert_no_error (error);
- g_assert (success);
- g_assert_cmpuint (cfun_query_power_state_tests[i].state, ==, state);
- }
-}
-
-typedef struct {
- const gchar *str;
- MMModemMode allowed;
- gint mbm_mode;
-} CfunQueryCurrentModeTest;
-
-static const CfunQueryCurrentModeTest cfun_query_current_mode_tests[] = {
- { "+CFUN: 0", MM_MODEM_MODE_NONE, -1 },
- { "+CFUN: 1", MM_MODEM_MODE_2G | MM_MODEM_MODE_3G, -1 },
- { "+CFUN: 4", MM_MODEM_MODE_NONE, -1 },
- { "+CFUN: 5", MM_MODEM_MODE_2G, MBM_NETWORK_MODE_2G },
- { "+CFUN: 6", MM_MODEM_MODE_3G, MBM_NETWORK_MODE_3G },
-};
-
-static void
-test_cfun_query_current_modes (void)
-{
- guint i;
-
- for (i = 0; i < G_N_ELEMENTS (cfun_query_current_mode_tests); i++) {
- GError *error = NULL;
- gboolean success;
- MMModemMode allowed = MM_MODEM_MODE_NONE;
- gint mbm_mode = -1;
-
- success = mm_mbm_parse_cfun_query_current_modes (cfun_query_current_mode_tests[i].str, &allowed, &mbm_mode, &error);
- g_assert_no_error (error);
- g_assert (success);
- g_assert_cmpuint (cfun_query_current_mode_tests[i].allowed, ==, allowed);
- g_assert_cmpint (cfun_query_current_mode_tests[i].mbm_mode, ==, mbm_mode);
- }
-}
-
-/*****************************************************************************/
-
-int main (int argc, char **argv)
-{
- setlocale (LC_ALL, "");
-
- g_test_init (&argc, &argv, NULL);
-
- g_test_add_func ("/MM/mbm/e2ipcfg", test_e2ipcfg);
- g_test_add_func ("/MM/mbm/cfun/test", test_cfun_test);
- g_test_add_func ("/MM/mbm/cfun/query/power-state", test_cfun_query_power_state);
- g_test_add_func ("/MM/mbm/cfun/query/current-modes", test_cfun_query_current_modes);
-
- return g_test_run ();
-}