| 1 | # -*-perl-*-
|
|---|
| 2 | # Date: Tue, 11 Aug 1992 09:34:26 -0400
|
|---|
| 3 | # From: pds@lemming.webo.dg.com (Paul D. Smith)
|
|---|
| 4 |
|
|---|
| 5 | $description = "Test load balancing (-l) option.";
|
|---|
| 6 |
|
|---|
| 7 | $details = "\
|
|---|
| 8 | This test creates a makefile where all depends on three rules
|
|---|
| 9 | which contain the same body. Each rule checks for the existence
|
|---|
| 10 | of a temporary file; if it exists an error is generated. If it
|
|---|
| 11 | doesn't exist then it is created, the rule sleeps, then deletes
|
|---|
| 12 | the temp file again. Thus if any of the rules are run in
|
|---|
| 13 | parallel the test will fail. When make is called in this test,
|
|---|
| 14 | it is given the -l option with a value of 0.0001. This ensures
|
|---|
| 15 | that the load will be above this number and make will therefore
|
|---|
| 16 | decide that it cannot run more than one job even though -j 4 was
|
|---|
| 17 | also specified on the command line.";
|
|---|
| 18 |
|
|---|
| 19 | open(MAKEFILE,"> $makefile");
|
|---|
| 20 |
|
|---|
| 21 | # The Contents of the MAKEFILE ...
|
|---|
| 22 |
|
|---|
| 23 | print MAKEFILE <<'EOF';
|
|---|
| 24 | SHELL = /bin/sh
|
|---|
| 25 |
|
|---|
| 26 | define test
|
|---|
| 27 | if [ ! -f test-file ]; then \
|
|---|
| 28 | echo >> test-file; sleep 2; rm -f test-file; \
|
|---|
| 29 | else \
|
|---|
| 30 | echo $@ FAILED; \
|
|---|
| 31 | fi
|
|---|
| 32 | endef
|
|---|
| 33 |
|
|---|
| 34 | all : ONE TWO THREE
|
|---|
| 35 | ONE : ; @$(test)
|
|---|
| 36 | TWO : ; @$(test)
|
|---|
| 37 | THREE : ; @$(test)
|
|---|
| 38 | EOF
|
|---|
| 39 |
|
|---|
| 40 |
|
|---|
| 41 | # END of Contents of MAKEFILE
|
|---|
| 42 |
|
|---|
| 43 | close(MAKEFILE);
|
|---|
| 44 |
|
|---|
| 45 | $mkoptions = "-l 0.0001";
|
|---|
| 46 | $mkoptions .= " -j 4" if ($parallel_jobs);
|
|---|
| 47 |
|
|---|
| 48 | # We have to wait longer than the default (5s).
|
|---|
| 49 | &run_make_with_options($makefile, $mkoptions, &get_logfile, 0, 8);
|
|---|
| 50 |
|
|---|
| 51 | $slurp = &read_file_into_string (&get_logfile(1));
|
|---|
| 52 | if ($slurp !~ /cannot enforce load limit/) {
|
|---|
| 53 | &compare_output("", &get_logfile(1));
|
|---|
| 54 | }
|
|---|
| 55 |
|
|---|
| 56 | 1;
|
|---|