~ubuntu-branches/ubuntu/raring/clamav/raring-updates

« back to all changes in this revision

Viewing changes to win32/3rdparty/pthreads/tests/condvar1_1.c

  • Committer: Bazaar Package Importer
  • Author(s): Scott Kitterman
  • Date: 2011-06-18 11:56:34 UTC
  • mfrom: (0.35.21 sid)
  • Revision ID: james.westby@ubuntu.com-20110618115634-u2lovivet0qx34d0
Tags: 0.97.1+dfsg-1ubuntu1
* Merge from debian unstable.  Remaining changes:
  - Drop build-dep on electric-fence (in Universe)
  - Add apparmor profiles for clamd and freshclam along with maintainer
    script changes

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * File: condvar1_1.c
3
 
 *
4
 
 *
5
 
 * --------------------------------------------------------------------------
6
 
 *
7
 
 *      Pthreads-win32 - POSIX Threads Library for Win32
8
 
 *      Copyright(C) 1998 John E. Bossom
9
 
 *      Copyright(C) 1999,2005 Pthreads-win32 contributors
10
 
 * 
11
 
 *      Contact Email: rpj@callisto.canberra.edu.au
12
 
 * 
13
 
 *      The current list of contributors is contained
14
 
 *      in the file CONTRIBUTORS included with the source
15
 
 *      code distribution. The list can also be seen at the
16
 
 *      following World Wide Web location:
17
 
 *      http://sources.redhat.com/pthreads-win32/contributors.html
18
 
 * 
19
 
 *      This library is free software; you can redistribute it and/or
20
 
 *      modify it under the terms of the GNU Lesser General Public
21
 
 *      License as published by the Free Software Foundation; either
22
 
 *      version 2 of the License, or (at your option) any later version.
23
 
 * 
24
 
 *      This library is distributed in the hope that it will be useful,
25
 
 *      but WITHOUT ANY WARRANTY; without even the implied warranty of
26
 
 *      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
27
 
 *      Lesser General Public License for more details.
28
 
 * 
29
 
 *      You should have received a copy of the GNU Lesser General Public
30
 
 *      License along with this library in the file COPYING.LIB;
31
 
 *      if not, write to the Free Software Foundation, Inc.,
32
 
 *      59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
33
 
 *
34
 
 * --------------------------------------------------------------------------
35
 
 *
36
 
 * Test Synopsis:
37
 
 * - Test CV linked list management.
38
 
 *
39
 
 * Test Method (Validation or Falsification):
40
 
 * - Validation:
41
 
 *   Initiate and destroy several CVs in random order.
42
 
 *
43
 
 * Requirements Tested:
44
 
 * - 
45
 
 *
46
 
 * Features Tested:
47
 
 * - 
48
 
 *
49
 
 * Cases Tested:
50
 
 * - 
51
 
 *
52
 
 * Description:
53
 
 * - Creates and then imediately destroys a CV. Does not
54
 
 *   test the CV.
55
 
 *
56
 
 * Environment:
57
 
 * - 
58
 
 *
59
 
 * Input:
60
 
 * - None.
61
 
 *
62
 
 * Output:
63
 
 * - File name, Line number, and failed expression on failure.
64
 
 * - No output on success.
65
 
 *
66
 
 * Assumptions:
67
 
 * -
68
 
 *
69
 
 * Pass Criteria:
70
 
 * - All initialised CVs destroyed without segfault.
71
 
 * - Successfully broadcasts all remaining CVs after
72
 
 *   each CV is removed.
73
 
 *
74
 
 * Fail Criteria:
75
 
 */
76
 
 
77
 
#include <stdlib.h>
78
 
#include "test.h"
79
 
 
80
 
enum {
81
 
  NUM_CV = 100
82
 
};
83
 
 
84
 
static pthread_cond_t cv[NUM_CV];
85
 
 
86
 
int
87
 
main()
88
 
{
89
 
  int i, j;
90
 
 
91
 
  for (i = 0; i < NUM_CV; i++)
92
 
    {
93
 
      /* Traverse the list before every init of a CV. */
94
 
      assert(pthread_timechange_handler_np(NULL) == (void *) 0);
95
 
      assert(pthread_cond_init(&cv[i], NULL) == 0);
96
 
    }
97
 
 
98
 
  j = NUM_CV;
99
 
  (void) srand((unsigned)time(NULL));
100
 
 
101
 
  do
102
 
    {
103
 
      i = (NUM_CV - 1) * rand() / RAND_MAX;
104
 
      if (cv[i] != NULL)
105
 
        {
106
 
          j--;
107
 
          assert(pthread_cond_destroy(&cv[i]) == 0);
108
 
          /* Traverse the list every time we remove a CV. */
109
 
          assert(pthread_timechange_handler_np(NULL) == (void *) 0);
110
 
        }
111
 
    }
112
 
  while (j > 0);
113
 
 
114
 
  return 0;
115
 
}