mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	As part of bringing the master branch back in to next, we need to allow for all of these changes to exist here. Reported-by: Jonas Karlman <jonas@kwiboo.se> Signed-off-by: Tom Rini <trini@konsulko.com>
		
			
				
	
	
		
			241 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			241 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0+
 | |
| /*
 | |
|  * Copyright (c) 2020, Heinrich Schuchardt <xypron.glpk@gmx.de>
 | |
|  *
 | |
|  * Logging function tests for CONFIG_LOG_SYSLOG=y.
 | |
|  *
 | |
|  * Invoke the test with: ./u-boot -d arch/sandbox/dts/test.dtb
 | |
|  */
 | |
| 
 | |
| /* Override CONFIG_LOG_MAX_LEVEL */
 | |
| #define LOG_DEBUG
 | |
| 
 | |
| #include <asm/global_data.h>
 | |
| #include <dm/device.h>
 | |
| #include <hexdump.h>
 | |
| #include <test/log.h>
 | |
| #include <test/test.h>
 | |
| #include <test/suites.h>
 | |
| #include <test/ut.h>
 | |
| #include <asm/eth.h>
 | |
| #include "syslog_test.h"
 | |
| 
 | |
| DECLARE_GLOBAL_DATA_PTR;
 | |
| 
 | |
| int sb_log_tx_handler(struct udevice *dev, void *packet, unsigned int len)
 | |
| {
 | |
| 	struct eth_sandbox_priv *priv = dev_get_priv(dev);
 | |
| 	struct sb_log_env *env = priv->priv;
 | |
| 	/* uts is updated by the ut_assert* macros */
 | |
| 	struct unit_test_state *uts = env->uts;
 | |
| 	char *buf = packet;
 | |
| 	struct ethernet_hdr *eth_hdr = packet;
 | |
| 	struct ip_udp_hdr *ip_udp_hdr;
 | |
| 
 | |
| 	/* Check Ethernet header */
 | |
| 	ut_asserteq_mem(ð_hdr->et_dest, net_bcast_ethaddr, ARP_HLEN);
 | |
| 	ut_asserteq(ntohs(eth_hdr->et_protlen), PROT_IP);
 | |
| 
 | |
| 	/* Check IP header */
 | |
| 	buf += sizeof(struct ethernet_hdr);
 | |
| 	ip_udp_hdr = (struct ip_udp_hdr *)buf;
 | |
| 	ut_asserteq(ip_udp_hdr->ip_p, IPPROTO_UDP);
 | |
| 	ut_asserteq(ip_udp_hdr->ip_dst.s_addr, 0xffffffff);
 | |
| 	ut_asserteq(ntohs(ip_udp_hdr->udp_dst), 514);
 | |
| 	ut_asserteq(UDP_HDR_SIZE + strlen(env->expected) + 1,
 | |
| 		    ntohs(ip_udp_hdr->udp_len));
 | |
| 
 | |
| 	/* Check payload */
 | |
| 	buf += sizeof(struct ip_udp_hdr);
 | |
| 	ut_asserteq_mem(env->expected, buf,
 | |
| 			ntohs(ip_udp_hdr->udp_len) - UDP_HDR_SIZE);
 | |
| 
 | |
| 	/* Signal that the callback function has been executed */
 | |
| 	env->expected = NULL;
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int syslog_test_setup(struct unit_test_state *uts)
 | |
| {
 | |
| 	ut_assertok(log_device_set_enable(LOG_GET_DRIVER(syslog), true));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int syslog_test_finish(struct unit_test_state *uts)
 | |
| {
 | |
| 	ut_assertok(log_device_set_enable(LOG_GET_DRIVER(syslog), false));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * log_test_syslog_err() - test log_err() function
 | |
|  *
 | |
|  * @uts:	unit test state
 | |
|  * Return:	0 = success
 | |
|  */
 | |
| static int log_test_syslog_err(struct unit_test_state *uts)
 | |
| {
 | |
| 	int old_log_level = gd->default_log_level;
 | |
| 	struct sb_log_env env;
 | |
| 
 | |
| 	ut_assertok(syslog_test_setup(uts));
 | |
| 	gd->log_fmt = LOGF_TEST;
 | |
| 	gd->default_log_level = LOGL_INFO;
 | |
| 	env_set("ethact", "eth@10002000");
 | |
| 	env_set("log_hostname", "sandbox");
 | |
| 	env.expected = "<3>sandbox uboot: log_test_syslog_err() "
 | |
| 		       "testing log_err\n";
 | |
| 	env.uts = uts;
 | |
| 	sandbox_eth_set_tx_handler(0, sb_log_tx_handler);
 | |
| 	/* Used by ut_assert macros in the tx_handler */
 | |
| 	sandbox_eth_set_priv(0, &env);
 | |
| 	log_err("testing %s\n", "log_err");
 | |
| 	/* Check that the callback function was called */
 | |
| 	sandbox_eth_set_tx_handler(0, NULL);
 | |
| 	gd->default_log_level = old_log_level;
 | |
| 	gd->log_fmt = log_get_default_format();
 | |
| 	ut_assertok(syslog_test_finish(uts));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| LOG_TEST(log_test_syslog_err);
 | |
| 
 | |
| /**
 | |
|  * log_test_syslog_warning() - test log_warning() function
 | |
|  *
 | |
|  * @uts:	unit test state
 | |
|  * Return:	0 = success
 | |
|  */
 | |
| static int log_test_syslog_warning(struct unit_test_state *uts)
 | |
| {
 | |
| 	int old_log_level = gd->default_log_level;
 | |
| 	struct sb_log_env env;
 | |
| 
 | |
| 	ut_assertok(syslog_test_setup(uts));
 | |
| 	gd->log_fmt = LOGF_TEST;
 | |
| 	gd->default_log_level = LOGL_INFO;
 | |
| 	env_set("ethact", "eth@10002000");
 | |
| 	env_set("log_hostname", "sandbox");
 | |
| 	env.expected = "<4>sandbox uboot: log_test_syslog_warning() "
 | |
| 		       "testing log_warning\n";
 | |
| 	env.uts = uts;
 | |
| 	sandbox_eth_set_tx_handler(0, sb_log_tx_handler);
 | |
| 	/* Used by ut_assert macros in the tx_handler */
 | |
| 	sandbox_eth_set_priv(0, &env);
 | |
| 	log_warning("testing %s\n", "log_warning");
 | |
| 	sandbox_eth_set_tx_handler(0, NULL);
 | |
| 	/* Check that the callback function was called */
 | |
| 	ut_assertnull(env.expected);
 | |
| 	gd->default_log_level = old_log_level;
 | |
| 	gd->log_fmt = log_get_default_format();
 | |
| 	ut_assertok(syslog_test_finish(uts));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| LOG_TEST(log_test_syslog_warning);
 | |
| 
 | |
| /**
 | |
|  * log_test_syslog_notice() - test log_notice() function
 | |
|  *
 | |
|  * @uts:	unit test state
 | |
|  * Return:	0 = success
 | |
|  */
 | |
| static int log_test_syslog_notice(struct unit_test_state *uts)
 | |
| {
 | |
| 	int old_log_level = gd->default_log_level;
 | |
| 	struct sb_log_env env;
 | |
| 
 | |
| 	ut_assertok(syslog_test_setup(uts));
 | |
| 	gd->log_fmt = LOGF_TEST;
 | |
| 	gd->default_log_level = LOGL_INFO;
 | |
| 	env_set("ethact", "eth@10002000");
 | |
| 	env_set("log_hostname", "sandbox");
 | |
| 	env.expected = "<5>sandbox uboot: log_test_syslog_notice() "
 | |
| 		       "testing log_notice\n";
 | |
| 	env.uts = uts;
 | |
| 	sandbox_eth_set_tx_handler(0, sb_log_tx_handler);
 | |
| 	/* Used by ut_assert macros in the tx_handler */
 | |
| 	sandbox_eth_set_priv(0, &env);
 | |
| 	log_notice("testing %s\n", "log_notice");
 | |
| 	sandbox_eth_set_tx_handler(0, NULL);
 | |
| 	/* Check that the callback function was called */
 | |
| 	ut_assertnull(env.expected);
 | |
| 	gd->default_log_level = old_log_level;
 | |
| 	gd->log_fmt = log_get_default_format();
 | |
| 	ut_assertok(syslog_test_finish(uts));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| LOG_TEST(log_test_syslog_notice);
 | |
| 
 | |
| /**
 | |
|  * log_test_syslog_info() - test log_info() function
 | |
|  *
 | |
|  * @uts:	unit test state
 | |
|  * Return:	0 = success
 | |
|  */
 | |
| static int log_test_syslog_info(struct unit_test_state *uts)
 | |
| {
 | |
| 	int old_log_level = gd->default_log_level;
 | |
| 	struct sb_log_env env;
 | |
| 
 | |
| 	ut_assertok(syslog_test_setup(uts));
 | |
| 	gd->log_fmt = LOGF_TEST;
 | |
| 	gd->default_log_level = LOGL_INFO;
 | |
| 	env_set("ethact", "eth@10002000");
 | |
| 	env_set("log_hostname", "sandbox");
 | |
| 	env.expected = "<6>sandbox uboot: log_test_syslog_info() "
 | |
| 		       "testing log_info\n";
 | |
| 	env.uts = uts;
 | |
| 	sandbox_eth_set_tx_handler(0, sb_log_tx_handler);
 | |
| 	/* Used by ut_assert macros in the tx_handler */
 | |
| 	sandbox_eth_set_priv(0, &env);
 | |
| 	log_info("testing %s\n", "log_info");
 | |
| 	sandbox_eth_set_tx_handler(0, NULL);
 | |
| 	/* Check that the callback function was called */
 | |
| 	ut_assertnull(env.expected);
 | |
| 	gd->default_log_level = old_log_level;
 | |
| 	gd->log_fmt = log_get_default_format();
 | |
| 	ut_assertok(syslog_test_finish(uts));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| LOG_TEST(log_test_syslog_info);
 | |
| 
 | |
| /**
 | |
|  * log_test_syslog_debug() - test log_debug() function
 | |
|  *
 | |
|  * @uts:	unit test state
 | |
|  * Return:	0 = success
 | |
|  */
 | |
| static int log_test_syslog_debug(struct unit_test_state *uts)
 | |
| {
 | |
| 	int old_log_level = gd->default_log_level;
 | |
| 	struct sb_log_env env;
 | |
| 
 | |
| 	ut_assertok(syslog_test_setup(uts));
 | |
| 	gd->log_fmt = LOGF_TEST;
 | |
| 	gd->default_log_level = LOGL_DEBUG;
 | |
| 	env_set("ethact", "eth@10002000");
 | |
| 	env_set("log_hostname", "sandbox");
 | |
| 	env.expected = "<7>sandbox uboot: log_test_syslog_debug() "
 | |
| 		       "testing log_debug\n";
 | |
| 	env.uts = uts;
 | |
| 	sandbox_eth_set_tx_handler(0, sb_log_tx_handler);
 | |
| 	/* Used by ut_assert macros in the tx_handler */
 | |
| 	sandbox_eth_set_priv(0, &env);
 | |
| 	log_debug("testing %s\n", "log_debug");
 | |
| 	sandbox_eth_set_tx_handler(0, NULL);
 | |
| 	/* Check that the callback function was called */
 | |
| 	ut_assertnull(env.expected);
 | |
| 	gd->default_log_level = old_log_level;
 | |
| 	gd->log_fmt = log_get_default_format();
 | |
| 	ut_assertok(syslog_test_finish(uts));
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| LOG_TEST(log_test_syslog_debug);
 |