takashi kadono / Mbed OS Nucleo_446

Dependencies:   ssd1331

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers synchronous_dns_cache.cpp Source File

synchronous_dns_cache.cpp

00001 /*
00002  * Copyright (c) 2018, ARM Limited, All Rights Reserved
00003  * SPDX-License-Identifier: Apache-2.0
00004  *
00005  * Licensed under the Apache License, Version 2.0 (the "License"); you may
00006  * not use this file except in compliance with the License.
00007  * You may obtain a copy of the License at
00008  *
00009  * http://www.apache.org/licenses/LICENSE-2.0
00010  *
00011  * Unless required by applicable law or agreed to in writing, software
00012  * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
00013  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00014  * See the License for the specific language governing permissions and
00015  * limitations under the License.
00016  */
00017 
00018 #include "mbed.h"
00019 #include "greentea-client/test_env.h"
00020 #include "unity.h"
00021 #include "utest.h"
00022 #include "dns_tests.h"
00023 
00024 using namespace utest::v1;
00025 
00026 namespace {
00027 int ticker_us = 0;
00028 }
00029 
00030 static void test_dns_query_ticker(void)
00031 {
00032     ticker_us += 100;
00033 }
00034 
00035 void SYNCHRONOUS_DNS_CACHE()
00036 {
00037     rtos::Semaphore semaphore;
00038 
00039     Ticker ticker;
00040     ticker.attach_us(&test_dns_query_ticker, 100);
00041 
00042     for (unsigned int i = 0; i < 5; i++) {
00043         SocketAddress address;
00044         int started_us = ticker_us;
00045         nsapi_error_t err = get_interface()->gethostbyname(dns_test_hosts_second[0], &address);
00046 
00047         int delay_ms = (ticker_us - started_us) / 1000;
00048 
00049         static int delay_first = delay_ms / 2;
00050         // Check that cached accesses are at least twice as fast as the first one
00051         TEST_ASSERT_TRUE(i == 0 || delay_ms <= delay_first);
00052 
00053         printf("DNS: query \"%s\" => \"%s\", time %i ms\n",
00054                dns_test_hosts_second[0], address.get_ip_address(), delay_ms);
00055     }
00056 }