202 lines
4.5 KiB
C
202 lines
4.5 KiB
C
/* $OpenBSD: test_strdelim.c,v 1.3 2021/12/14 21:25:27 deraadt Exp $ */
|
|
/*
|
|
* Regress test for misc strdelim() and co
|
|
*
|
|
* Placed in the public domain.
|
|
*/
|
|
|
|
#include "includes.h"
|
|
|
|
#include <sys/types.h>
|
|
#include <stdio.h>
|
|
#ifdef HAVE_STDINT_H
|
|
#include <stdint.h>
|
|
#endif
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include "../test_helper/test_helper.h"
|
|
|
|
#include "log.h"
|
|
#include "misc.h"
|
|
#include "xmalloc.h"
|
|
|
|
void test_strdelim(void);
|
|
|
|
void
|
|
test_strdelim(void)
|
|
{
|
|
char *orig, *str, *cp;
|
|
|
|
#define START_STRING(x) orig = str = xstrdup(x)
|
|
#define DONE_STRING() free(orig)
|
|
|
|
TEST_START("empty");
|
|
START_STRING("");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, ""); /* XXX arguable */
|
|
cp = strdelim(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("whitespace");
|
|
START_STRING(" ");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, ""); /* XXX better as NULL */
|
|
ASSERT_STRING_EQ(str, "");
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("trivial");
|
|
START_STRING("blob");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob");
|
|
cp = strdelim(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("trivial whitespace");
|
|
START_STRING("blob ");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob");
|
|
ASSERT_STRING_EQ(str, "");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, ""); /* XXX better as NULL */
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("multi");
|
|
START_STRING("blob1 blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1");
|
|
ASSERT_STRING_EQ(str, "blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob2");
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
cp = strdelim(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("multi whitespace");
|
|
START_STRING("blob1 blob2 ");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1");
|
|
ASSERT_STRING_EQ(str, "blob2 ");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, ""); /* XXX better as NULL */
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("multi equals");
|
|
START_STRING("blob1=blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1");
|
|
ASSERT_STRING_EQ(str, "blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob2");
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
cp = strdelim(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("multi too many equals");
|
|
START_STRING("blob1==blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1"); /* XXX better returning NULL early */
|
|
ASSERT_STRING_EQ(str, "=blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "");
|
|
ASSERT_STRING_EQ(str, "blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob2"); /* XXX should (but can't) reject */
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("multi equals strdelimw");
|
|
START_STRING("blob1=blob2");
|
|
cp = strdelimw(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1=blob2");
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
cp = strdelimw(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("quoted");
|
|
START_STRING("\"blob\"");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, ""); /* XXX better as NULL */
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("quoted multi");
|
|
START_STRING("\"blob1\" blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1");
|
|
ASSERT_STRING_EQ(str, "blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob2");
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
cp = strdelim(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("quoted multi reverse");
|
|
START_STRING("blob1 \"blob2\"");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1");
|
|
ASSERT_STRING_EQ(str, "\"blob2\"");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob2");
|
|
ASSERT_STRING_EQ(str, "");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, ""); /* XXX better as NULL */
|
|
ASSERT_PTR_EQ(str, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("quoted multi middle");
|
|
START_STRING("blob1 \"blob2\" blob3");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob1");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob2");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob3");
|
|
cp = strdelim(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("badquote");
|
|
START_STRING("\"blob");
|
|
cp = strdelim(&str);
|
|
ASSERT_PTR_EQ(cp, NULL);
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
TEST_START("oops quote");
|
|
START_STRING("\"blob\\\"");
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "blob\\"); /* XXX wrong */
|
|
cp = strdelim(&str);
|
|
ASSERT_STRING_EQ(cp, "");
|
|
DONE_STRING();
|
|
TEST_DONE();
|
|
|
|
}
|