2 # Regular examples: with only one source and tested with all factories by default
3 #################################################################################
4 ### Define the examples' specificities
6 set(_app-bittorrent_sources app-bittorrent/s4u-bittorrent.cpp app-bittorrent/s4u-bittorrent.hpp
7 app-bittorrent/s4u-peer.cpp app-bittorrent/s4u-peer.hpp
8 app-bittorrent/s4u-tracker.cpp app-bittorrent/s4u-tracker.hpp)
9 set(_dht-chord_sources dht-chord/s4u-dht-chord.cpp dht-chord/s4u-dht-chord.hpp dht-chord/s4u-dht-chord-node.cpp)
10 set(_dht-kademlia_sources dht-kademlia/s4u-dht-kademlia.cpp dht-kademlia/s4u-dht-kademlia.hpp
11 dht-kademlia/node.cpp dht-kademlia/node.hpp
12 dht-kademlia/routing_table.cpp dht-kademlia/routing_table.hpp
13 dht-kademlia/answer.cpp dht-kademlia/answer.hpp dht-kademlia/message.hpp)
15 set(_actor-stacksize_factories "^thread") # Threads ignore modifications of the stack size
17 # The maestro-set example only works for threads and when not using windows.
18 set(_maestro-set_factories "thread")
20 set(_maestro-set_disable 1)
24 # These tests timeout with threads, maybe because of dwarf parsing? not sure
25 foreach(example mc-bugged1 mc-bugged2 mc-failing-assert mc-electric-fence)
26 set(_${example}_factories "^thread") # Timeout
27 add_dependencies(tests-mc s4u-${example})
30 if(HAVE_C_STACK_CLEANER)
31 add_executable (s4u-mc-bugged1-liveness-cleaner-on EXCLUDE_FROM_ALL s4u-mc-bugged1-liveness/s4u-mc-bugged1-liveness.cpp)
32 target_link_libraries(s4u-mc-bugged1-liveness-cleaner-on simgrid)
33 set_target_properties(s4u-mc-bugged1-liveness-cleaner-on PROPERTIES COMPILE_FLAGS "-DGARBAGE_STACK -fstack-cleaner")
34 add_dependencies(tests-mc s4u-mc-bugged1-liveness-cleaner-on)
36 add_executable (s4u-mc-bugged1-liveness-cleaner-off EXCLUDE_FROM_ALL s4u-mc-bugged1-liveness/s4u-mc-bugged1-liveness.cpp)
37 target_link_libraries(s4u-mc-bugged1-liveness-cleaner-off simgrid)
38 set_target_properties(s4u-mc-bugged1-liveness-cleaner-off PROPERTIES COMPILE_FLAGS "-DGARBAGE_STACK -fno-stack-cleaner")
39 add_dependencies(tests-mc s4u-mc-bugged1-liveness-cleaner-off)
42 # Model-checking liveness
43 if(HAVE_UCONTEXT_CONTEXTS AND SIMGRID_PROCESSOR_x86_64)
44 # liveness model-checking works only on 64bits (for now ...)
45 set(_mc-bugged1-liveness_factories "ucontext") # Timeout
46 add_dependencies(tests-mc s4u-mc-bugged1-liveness)
47 set(_mc-bugged2-liveness_factories "ucontext") # Timeout
49 set(_mc-bugged1-liveness_disable 1)
52 # This example never ends, disable it for now
53 set(_mc-bugged2-liveness_disable 1)
55 # This example hit the 5' timeout on CI, disable it for now
56 # ADD_TESH(s4u-mc-bugged1-liveness-visited-ucontext --setenv bindir=${CMAKE_CURRENT_BINARY_DIR}/mc-bugged1-liveness
57 # --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
58 # --cd ${CMAKE_CURRENT_SOURCE_DIR}/mc-bugged1-liveness
59 # ${CMAKE_HOME_DIRECTORY}/examples/cpp/mc-bugged1-liveness/s4u-mc-bugged1-liveness-visited.tesh)
60 IF(HAVE_C_STACK_CLEANER)
61 add_dependencies(tests-mc s4u-mc-bugged1-liveness-stack-cleaner)
62 # This test checks if the stack cleaner is making a difference:
63 ADD_TEST(s4u-mc-bugged1-liveness-stack-cleaner ${CMAKE_HOME_DIRECTORY}/examples/cpp/mc-bugged1-liveness/s4u-mc-bugged1-liveness-stack-cleaner
64 ${CMAKE_HOME_DIRECTORY}/examples/cpp/mc-bugged1-liveness/
65 ${CMAKE_CURRENT_BINARY_DIR}/mc-bugged1-liveness/)
69 foreach (example mc-bugged1 mc-bugged2 mc-electric-fence mc-failing-assert)
70 ADD_TEST(cover-${example} ${CMAKE_CURRENT_BINARY_DIR}/${example}/s4u-${example} ${CMAKE_HOME_DIRECTORY}/examples/platforms/model_checker_platform.xml)
72 ADD_TEST(cover-mc-bugged1-liveness ${CMAKE_CURRENT_BINARY_DIR}/mc-bugged1-liveness/s4u-mc-bugged1-liveness ${CMAKE_HOME_DIRECTORY}/examples/platforms/small_platform.xml 1 1001)
76 foreach (example mc-bugged1 mc-bugged2 mc-centralized-mutex mc-failing-assert mc-electric-fence
77 mc-bugged1-liveness mc-bugged2-liveness)
78 set(_${example}_disable 1)
82 # Hijack some regular tests to run them on top of the MC
83 foreach (example synchro-barrier synchro-mutex synchro-semaphore)
84 set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/${example}/s4u-mc-${example}.tesh)
87 ADD_TESH(s4u-mc-${example}
88 --setenv bindir=${CMAKE_CURRENT_BINARY_DIR}/${example}
89 --setenv libdir=${CMAKE_BINARY_DIR}/lib
90 --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
91 --setenv srcdir=${CMAKE_CURRENT_SOURCE_DIR}/${example}
92 --cd ${CMAKE_CURRENT_SOURCE_DIR}/${example}
93 ${CMAKE_HOME_DIRECTORY}/examples/cpp/${example}/s4u-mc-${example}.tesh)
99 set(_dag-from-dot_disable 1)
102 if(NOT SIMGRID_HAVE_NS3)
103 foreach (example network-ns3 network-ns3-wifi)
104 set(_${example}_disable 1)
108 # Deal with each example
110 foreach (example activity-testany activity-waitany
111 actor-create actor-daemon actor-exiting actor-join actor-kill
112 actor-lifetime actor-migrate actor-suspend actor-yield actor-stacksize
113 app-bittorrent app-chainsend app-token-ring
114 comm-pingpong comm-ready comm-serialize comm-suspend comm-testany comm-wait comm-waitany comm-waitall comm-waituntil
115 comm-dependent comm-host2host comm-failure comm-throttling
116 cloud-capping cloud-migration cloud-simple
117 dag-comm dag-from-dax dag-from-dot dag-failure dag-io dag-scheduling dag-simple
118 dht-chord dht-kademlia
119 energy-exec energy-boot energy-link energy-vm energy-exec-ptask energy-wifi
120 engine-filtering engine-run-partial
121 exec-async exec-basic exec-dvfs exec-remote exec-waitany exec-waitfor exec-dependent exec-unassigned
122 exec-ptask-multicore exec-ptask-multicore-latency exec-cpu-nonlinear exec-cpu-factors exec-failure exec-thread
124 mc-bugged1 mc-bugged1-liveness mc-bugged2 mc-bugged2-liveness mc-centralized-mutex mc-electric-fence mc-failing-assert
125 network-ns3 network-ns3-wifi network-wifi
126 io-async io-priority io-degradation io-file-system io-file-remote io-disk-raw io-dependent
127 platform-failures platform-profile platform-properties
128 plugin-host-load plugin-link-load plugin-prodcons
129 replay-comm replay-io
131 synchro-barrier synchro-condition-variable synchro-condition-variable-waituntil synchro-mutex synchro-semaphore
132 clusters-multicpu network-factors network-nonlinear)
134 # Use default source file unless specified otherwise
135 if(NOT DEFINED _${example}_sources)
136 set(_${example}_sources ${example}/s4u-${example}.cpp)
139 if(NOT DEFINED _${example}_disable)
140 add_executable (s4u-${example} EXCLUDE_FROM_ALL ${_${example}_sources})
141 add_dependencies (tests s4u-${example})
142 add_dependencies (s4u-${example} platf_cpp)
143 target_link_libraries(s4u-${example} simgrid)
144 set_target_properties(s4u-${example} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${example})
146 # Use default factories unless specified otherwise
147 if(NOT DEFINED _${example}_factories)
148 set(_${example}_factories "*")
150 # message("Factories of ${example}: ${_${example}_factories}")
152 ADD_TESH_FACTORIES(s4u-${example} "${_${example}_factories}"
153 --setenv bindir=${CMAKE_CURRENT_BINARY_DIR}/${example}
154 --setenv libdir=${CMAKE_BINARY_DIR}/lib
155 --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
156 --setenv srcdir=${CMAKE_CURRENT_SOURCE_DIR}/${example}
157 --cd ${CMAKE_CURRENT_SOURCE_DIR}/${example}
158 ${CMAKE_HOME_DIRECTORY}/examples/cpp/${example}/s4u-${example}.tesh)
160 message(STATUS "Example ${example} disabled, thus not compiled.")
161 unset(_${example}_disable)
164 set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/${example}/s4u-${example}.tesh)
165 foreach(file ${_${example}_sources})
166 set(examples_src ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/${file})
169 unset(_${example}_factories)
170 unset(_${example}_sources)
177 # MASTERWORKERS EXAMPLE
178 foreach(variant fun class)
179 add_executable (s4u-app-masterworkers-${variant} EXCLUDE_FROM_ALL app-masterworkers/s4u-app-masterworkers-${variant}.cpp)
180 target_link_libraries(s4u-app-masterworkers-${variant} simgrid)
181 set_target_properties(s4u-app-masterworkers-${variant} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/app-masterworkers)
182 add_dependencies(tests s4u-app-masterworkers-${variant})
184 set(examples_src ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworkers/s4u-app-masterworkers-${variant}.cpp)
186 set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworkers/s4u-app-masterworkers.tesh)
188 # The tests the parallel variant of of DHTs
190 if(CMAKE_SYSTEM_NAME STREQUAL "SunOS" AND CMAKE_SYSTEM_PROCESSOR STREQUAL "i386" AND CMAKE_SIZEOF_VOID_P EQUAL 8)
191 # Thread-local storage (TLS) is needed for parallel execution, but it doesn't
192 # play well with Ucontexts on 64bit SunOS (at least on x86_64).
193 set(parallel-factories "^ucontext")
195 set(parallel-factories "*")
198 foreach(example app-bittorrent app-masterworkers
199 dht-chord dht-kademlia
201 ADD_TESH_FACTORIES(s4u-${example}-parallel "${parallel-factories}" --cfg contexts/nthreads:4 ${CONTEXTS_SYNCHRO}
202 --setenv bindir=${CMAKE_CURRENT_BINARY_DIR}/${example}
203 --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
204 --cd ${CMAKE_CURRENT_SOURCE_DIR}/${example}
205 ${CMAKE_HOME_DIRECTORY}/examples/cpp/${example}/s4u-${example}.tesh)
208 # Examples not accepting factories
209 ##################################
211 foreach (example exec-ptask trace-categories trace-masterworkers trace-platform trace-process-migration
212 trace-host-user-variables trace-link-user-variables trace-route-user-variables)
213 add_executable (s4u-${example} EXCLUDE_FROM_ALL ${example}/s4u-${example}.cpp)
214 target_link_libraries(s4u-${example} simgrid)
215 set_target_properties(s4u-${example} PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${example})
216 add_dependencies(tests s4u-${example})
218 set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/${example}/s4u-${example}.tesh)
219 set(examples_src ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/${example}/s4u-${example}.cpp)
221 ADD_TESH(s4u-${example} --setenv bindir=${CMAKE_CURRENT_BINARY_DIR}/${example}
222 --setenv srcdir=${CMAKE_CURRENT_SOURCE_DIR}/${example}
223 --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
224 --cd ${CMAKE_CURRENT_BINARY_DIR}/${example}
225 ${CMAKE_HOME_DIRECTORY}/examples/cpp/${example}/s4u-${example}.tesh)
228 if (NOT enable_memcheck AND NOT WIN32)
229 ADD_TESH(simix-breakpoint --setenv bindir=${CMAKE_CURRENT_BINARY_DIR}/comm-pingpong
230 --setenv platfdir=${CMAKE_HOME_DIRECTORY}/examples/platforms
231 ${CMAKE_CURRENT_SOURCE_DIR}/comm-pingpong/simix-breakpoint.tesh)
234 # Add all extra files to the archive
235 ####################################
236 set(examples_src ${examples_src} ${CMAKE_CURRENT_SOURCE_DIR}/mc-bugged1-liveness/s4u-mc-bugged1-liveness.cpp PARENT_SCOPE)
237 set(tesh_files ${tesh_files} ${CMAKE_CURRENT_SOURCE_DIR}/comm-pingpong/simix-breakpoint.tesh
238 ${CMAKE_CURRENT_SOURCE_DIR}/mc-bugged1-liveness/s4u-mc-bugged1-liveness.tesh
239 ${CMAKE_CURRENT_SOURCE_DIR}/mc-bugged1-liveness/s4u-mc-bugged1-liveness-visited.tesh PARENT_SCOPE)
240 set(xml_files ${xml_files} ${CMAKE_CURRENT_SOURCE_DIR}/actor-create/s4u-actor-create_d.xml
241 ${CMAKE_CURRENT_SOURCE_DIR}/actor-lifetime/s4u-actor-lifetime_d.xml
242 ${CMAKE_CURRENT_SOURCE_DIR}/app-bittorrent/s4u-app-bittorrent_d.xml
243 ${CMAKE_CURRENT_SOURCE_DIR}/app-masterworkers/s4u-app-masterworkers_d.xml
244 ${CMAKE_CURRENT_SOURCE_DIR}/dag-scheduling/Montage_25.xml
245 ${CMAKE_CURRENT_SOURCE_DIR}/dht-chord/s4u-dht-chord_d.xml
246 ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/s4u-dht-kademlia_d.xml
247 ${CMAKE_CURRENT_SOURCE_DIR}/io-file-remote/s4u-io-file-remote_d.xml
248 ${CMAKE_CURRENT_SOURCE_DIR}/platform-failures/s4u-platform-failures_d.xml
249 ${CMAKE_CURRENT_SOURCE_DIR}/replay-comm/s4u-replay-comm-split_d.xml
250 ${CMAKE_CURRENT_SOURCE_DIR}/replay-comm/s4u-replay-comm_d.xml
251 ${CMAKE_CURRENT_SOURCE_DIR}/replay-io/s4u-replay-io_d.xml
252 ${CMAKE_CURRENT_SOURCE_DIR}/network-ns3/3hosts_2links_d.xml
253 ${CMAKE_CURRENT_SOURCE_DIR}/network-ns3/3links-timer_d.xml
254 ${CMAKE_CURRENT_SOURCE_DIR}/network-ns3/3links_d.xml
255 ${CMAKE_CURRENT_SOURCE_DIR}/network-ns3/crosstraffic_d.xml
256 ${CMAKE_CURRENT_SOURCE_DIR}/network-ns3/dogbone_d.xml
257 ${CMAKE_CURRENT_SOURCE_DIR}/network-ns3/onelink_d.xml
258 ${CMAKE_CURRENT_SOURCE_DIR}/network-ns3/one_cluster_d.xml PARENT_SCOPE)
259 set(bin_files ${bin_files} ${CMAKE_CURRENT_SOURCE_DIR}/dht-kademlia/generate.py
260 ${CMAKE_CURRENT_SOURCE_DIR}/mc-bugged1-liveness/s4u-mc-bugged1-liveness-stack-cleaner
261 ${CMAKE_CURRENT_SOURCE_DIR}/mc-bugged1-liveness/promela_bugged1_liveness
262 ${CMAKE_CURRENT_SOURCE_DIR}/mc-bugged2-liveness/promela_bugged2_liveness PARENT_SCOPE)
263 set(txt_files ${txt_files} ${CMAKE_CURRENT_SOURCE_DIR}/dag-from-dax/simple_dax_with_cycle.xml
264 ${CMAKE_CURRENT_SOURCE_DIR}/dag-from-dax/smalldax.xml
265 ${CMAKE_CURRENT_SOURCE_DIR}/dag-from-dot/dag.dot
266 ${CMAKE_CURRENT_SOURCE_DIR}/dag-from-dot/dag_with_cycle.dot
267 ${CMAKE_CURRENT_SOURCE_DIR}/replay-comm/s4u-replay-comm-split-p0.txt
268 ${CMAKE_CURRENT_SOURCE_DIR}/replay-comm/s4u-replay-comm-split-p1.txt
269 ${CMAKE_CURRENT_SOURCE_DIR}/replay-comm/s4u-replay-comm.txt
270 ${CMAKE_CURRENT_SOURCE_DIR}/replay-io/s4u-replay-io.txt PARENT_SCOPE)