os161/kern/test/arraytest.c
2015-12-23 00:50:04 +00:00

218 lines
5.0 KiB
C

/*
* Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005, 2008, 2009
* The President and Fellows of Harvard College.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#include <types.h>
#include <lib.h>
#include <array.h>
#include <test.h>
#define TESTSIZE 73
#define BIGTESTSIZE 3000 /* more than one page of pointers */
#define NTH(i) ((void *)(0xb007 + 3*(i)))
static
void
testa(struct array *a)
{
int testarray[TESTSIZE];
int i, j, n, r, *p;
for (i=0; i<TESTSIZE; i++) {
testarray[i]=i;
}
n = array_num(a);
KASSERT(n==0);
for (i=0; i<TESTSIZE; i++) {
r = array_add(a, &testarray[i], NULL);
KASSERT(r==0);
n = array_num(a);
KASSERT(n==i+1);
}
n = array_num(a);
KASSERT(n==TESTSIZE);
for (i=0; i<TESTSIZE; i++) {
p = array_get(a, i);
KASSERT(*p == i);
}
n = array_num(a);
KASSERT(n==TESTSIZE);
for (j=0; j<TESTSIZE*4; j++) {
i = random()%TESTSIZE;
p = array_get(a, i);
KASSERT(*p == i);
}
n = array_num(a);
KASSERT(n==TESTSIZE);
for (i=0; i<TESTSIZE; i++) {
array_set(a, i, &testarray[TESTSIZE-i-1]);
}
for (i=0; i<TESTSIZE; i++) {
p = array_get(a, i);
KASSERT(*p == TESTSIZE-i-1);
}
r = array_setsize(a, TESTSIZE/2);
KASSERT(r==0);
for (i=0; i<TESTSIZE/2; i++) {
p = array_get(a, i);
KASSERT(*p == TESTSIZE-i-1);
}
array_remove(a, 1);
for (i=1; i<TESTSIZE/2 - 1; i++) {
p = array_get(a, i);
KASSERT(*p == TESTSIZE-i-2);
}
p = array_get(a, 0);
KASSERT(*p == TESTSIZE-1);
array_setsize(a, 2);
p = array_get(a, 0);
KASSERT(*p == TESTSIZE-1);
p = array_get(a, 1);
KASSERT(*p == TESTSIZE-3);
array_set(a, 1, NULL);
array_setsize(a, 2);
p = array_get(a, 0);
KASSERT(*p == TESTSIZE-1);
p = array_get(a, 1);
KASSERT(p==NULL);
array_setsize(a, TESTSIZE*10);
p = array_get(a, 0);
KASSERT(*p == TESTSIZE-1);
p = array_get(a, 1);
KASSERT(p==NULL);
}
int
arraytest(int nargs, char **args)
{
struct array *a;
(void)nargs;
(void)args;
kprintf("Beginning array test...\n");
a = array_create();
KASSERT(a != NULL);
testa(a);
array_setsize(a, 0);
testa(a);
array_setsize(a, 0);
array_destroy(a);
kprintf("Array test complete\n");
return 0;
}
int
arraytest2(int nargs, char **args)
{
struct array *a;
void *p;
unsigned i, x;
int result;
(void)nargs;
(void)args;
kprintf("Beginning large array test...\n");
a = array_create();
KASSERT(a != NULL);
/* 1. Fill it one at a time. */
p = (void *)0xc0ffee;
for (i=0; i<BIGTESTSIZE; i++) {
result = array_add(a, p, &x);
KASSERT(result == 0);
KASSERT(x == i);
}
KASSERT(array_num(a) == BIGTESTSIZE);
/* 2. Check the contents */
for (i=0; i<BIGTESTSIZE; i++) {
KASSERT(array_get(a, i) == p);
}
/* 3. Clear it */
result = array_setsize(a, 0);
KASSERT(result == 0);
/* 4. Set the size and initialize with array_set */
result = array_setsize(a, BIGTESTSIZE);
KASSERT(result == 0);
for (i=0; i<BIGTESTSIZE; i++) {
array_set(a, i, NTH(i));
}
/* 5. Check the contents again */
for (i=0; i<BIGTESTSIZE; i++) {
KASSERT(array_get(a, i) == NTH(i));
}
/* 6. Zot an entry and check the contents */
array_remove(a, 1);
KASSERT(array_get(a, 0) == NTH(0));
KASSERT(array_num(a) == BIGTESTSIZE-1);
for (i=1; i<BIGTESTSIZE-1; i++) {
KASSERT(array_get(a, i) == NTH(i+1));
}
/* 7. Double the size and check the preexisting contents */
result = array_setsize(a, BIGTESTSIZE*2);
KASSERT(result == 0);
KASSERT(array_get(a, 0) == NTH(0));
for (i=1; i<BIGTESTSIZE-1; i++) {
KASSERT(array_get(a, i) == NTH(i+1));
}
/* done */
result = array_setsize(a, 0);
KASSERT(result == 0);
array_destroy(a);
kprintf("Done.\n");
return 0;
}