File: StackTrace.cpp

package info (click to toggle)
storm-lang 0.7.4-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 52,004 kB
  • sloc: ansic: 261,462; cpp: 140,405; sh: 14,891; perl: 9,846; python: 2,525; lisp: 2,504; asm: 860; makefile: 678; pascal: 70; java: 52; xml: 37; awk: 12
file content (43 lines) | stat: -rw-r--r-- 931 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#include "stdafx.h"
#include "OS/Thread.h"
#include "OS/ThreadGroup.h"
#include "OS/StackTrace.h"
#include "OS/Sync.h"

static os::Sema waitSema(0);

static void auxThread() {
	waitSema.down();
}


BEGIN_TESTX(StackTraceTest, OS) {
	os::ThreadGroup g;

	{
		os::Thread a = os::Thread::current();
		os::Thread b = os::Thread::spawn(util::simpleVoidFn(auxThread), g);
		os::UThread::spawn(util::simpleVoidFn(auxThread));
		os::UThread::spawn(util::simpleVoidFn(auxThread), &b);

		vector<os::Thread> threads = g.threads();
		threads.push_back(a);

		vector<vector<::StackTrace>> traces = os::stackTraces(threads);

		for (int i = 0; i < 4; i++)
			waitSema.up();

		for (size_t i = 0; i < traces.size(); i++) {
			PLN(L"Thread " << i << L":");
			::Indent z(util::debugStream());
			for (size_t j = 0; j < traces[i].size(); j++) {
				PLN(L"UThread " << j << L":");
				PLN(format(traces[i][j]));
			}
		}
	}

	g.join();

} END_TEST