1570af302Sopenharmony_ci/*
2570af302Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
3570af302Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4570af302Sopenharmony_ci * you may not use this file except in compliance with the License.
5570af302Sopenharmony_ci * You may obtain a copy of the License at
6570af302Sopenharmony_ci *
7570af302Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8570af302Sopenharmony_ci *
9570af302Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10570af302Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11570af302Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12570af302Sopenharmony_ci * See the License for the specific language governing permissions and
13570af302Sopenharmony_ci * limitations under the License.
14570af302Sopenharmony_ci */
15570af302Sopenharmony_ci
16570af302Sopenharmony_ci#include <stdio.h>
17570af302Sopenharmony_ci#include <stdlib.h>
18570af302Sopenharmony_ci#include <string.h>
19570af302Sopenharmony_ci#include <search.h>
20570af302Sopenharmony_ci#include <time.h>
21570af302Sopenharmony_ci#include "test.h"
22570af302Sopenharmony_ci
23570af302Sopenharmony_ci#define ARRAY_SIZE (10)
24570af302Sopenharmony_cistatic void *root = NULL;
25570af302Sopenharmony_cistatic int g_free_calls = 0;
26570af302Sopenharmony_ci
27570af302Sopenharmony_civoid *malloc_node(unsigned n)
28570af302Sopenharmony_ci{
29570af302Sopenharmony_ci    void *p;
30570af302Sopenharmony_ci    p = malloc(n);
31570af302Sopenharmony_ci    if (p) {
32570af302Sopenharmony_ci        return p;
33570af302Sopenharmony_ci    }
34570af302Sopenharmony_ci    fprintf(stderr, "insufficient memory\n");
35570af302Sopenharmony_ci    exit(EXIT_FAILURE);
36570af302Sopenharmony_ci}
37570af302Sopenharmony_ci
38570af302Sopenharmony_ciint cmp_node(const void *pa, const void *pb)
39570af302Sopenharmony_ci{
40570af302Sopenharmony_ci    if (*(int *)pa < *(int *)pb) {
41570af302Sopenharmony_ci        return -1;
42570af302Sopenharmony_ci    }
43570af302Sopenharmony_ci    if (*(int *)pa > *(int *)pb) {
44570af302Sopenharmony_ci        return 1;
45570af302Sopenharmony_ci    }
46570af302Sopenharmony_ci    return 0;
47570af302Sopenharmony_ci}
48570af302Sopenharmony_ci
49570af302Sopenharmony_civoid node_free(void *p)
50570af302Sopenharmony_ci{
51570af302Sopenharmony_ci    free(p);
52570af302Sopenharmony_ci    g_free_calls++;
53570af302Sopenharmony_ci}
54570af302Sopenharmony_ci
55570af302Sopenharmony_ci/**
56570af302Sopenharmony_ci * @tc.name      : tdestroy_0100
57570af302Sopenharmony_ci * @tc.desc      : Removes the whole tree pointed to by root
58570af302Sopenharmony_ci * @tc.level     : Level 0
59570af302Sopenharmony_ci */
60570af302Sopenharmony_civoid tdestroy_0100(void)
61570af302Sopenharmony_ci{
62570af302Sopenharmony_ci    int i, *ptr, *target;
63570af302Sopenharmony_ci    void *val, *result;
64570af302Sopenharmony_ci    int array[ARRAY_SIZE] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
65570af302Sopenharmony_ci
66570af302Sopenharmony_ci    for (i = 0; i < ARRAY_SIZE; i++) {
67570af302Sopenharmony_ci        ptr = malloc_node(sizeof(int));
68570af302Sopenharmony_ci        *ptr = array[i];
69570af302Sopenharmony_ci        val = tsearch((void *)ptr, &root, cmp_node);
70570af302Sopenharmony_ci        if (val == NULL) {
71570af302Sopenharmony_ci            exit(EXIT_FAILURE);
72570af302Sopenharmony_ci
73570af302Sopenharmony_ci        } else if ((*(int **)val) != ptr) {
74570af302Sopenharmony_ci            free(ptr);
75570af302Sopenharmony_ci        }
76570af302Sopenharmony_ci    }
77570af302Sopenharmony_ci
78570af302Sopenharmony_ci    tdestroy(root, node_free);
79570af302Sopenharmony_ci    if (g_free_calls != ARRAY_SIZE) {
80570af302Sopenharmony_ci        t_error("%s tdestroy failed, g_free_calls is %d\n", __func__, g_free_calls);
81570af302Sopenharmony_ci    }
82570af302Sopenharmony_ci}
83570af302Sopenharmony_ci
84570af302Sopenharmony_ciint main(int argc, char *argv[])
85570af302Sopenharmony_ci{
86570af302Sopenharmony_ci    tdestroy_0100();
87570af302Sopenharmony_ci    return t_status;
88570af302Sopenharmony_ci}