blob: 4901792589729aa508b51339023302256216a5ae [file] [log] [blame]
Douglas Gregor527b1c92013-03-25 21:19:16 +00001// Test the automatic pruning of module cache entries.
2#ifdef IMPORT_DEPENDS_ON_MODULE
3@import DependsOnModule;
4#else
5@import Module;
6#endif
7
8// We need 'touch' and 'find' for this test to work.
9// REQUIRES: shell
10
11// Clear out the module cache
12// RUN: rm -rf %t
13// Run Clang twice so we end up creating the timestamp file (the second time).
14// RUN: %clang_cc1 -DIMPORT_DEPENDS_ON_MODULE -fmodules-ignore-macro=DIMPORT_DEPENDS_ON_MODULE -fmodules -F %S/Inputs -fmodules-cache-path=%t %s -verify
15// RUN: %clang_cc1 -DIMPORT_DEPENDS_ON_MODULE -fmodules-ignore-macro=DIMPORT_DEPENDS_ON_MODULE -fmodules -F %S/Inputs -fmodules-cache-path=%t %s -verify
16// RUN: ls %t | grep modules.timestamp
Ben Langmuirbeee15e2014-04-14 18:00:01 +000017// RUN: ls -R %t | grep ^Module.*pcm
18// RUN: ls -R %t | grep DependsOnModule.*pcm
Douglas Gregor527b1c92013-03-25 21:19:16 +000019
20// Set the timestamp back more than two days. We should try to prune,
21// but nothing gets pruned because the module files are new enough.
Douglas Gregor1f37ddd2013-03-25 21:27:57 +000022// RUN: touch -m -a -t 201101010000 %t/modules.timestamp
Douglas Gregor527b1c92013-03-25 21:19:16 +000023// RUN: %clang_cc1 -fmodules -F %S/Inputs -fmodules-cache-path=%t -fmodules -fmodules-prune-interval=172800 -fmodules-prune-after=345600 %s -verify
24// RUN: ls %t | grep modules.timestamp
Ben Langmuirbeee15e2014-04-14 18:00:01 +000025// RUN: ls -R %t | grep ^Module.*pcm
26// RUN: ls -R %t | grep DependsOnModule.*pcm
Douglas Gregor527b1c92013-03-25 21:19:16 +000027
28// Set the DependsOnModule access time back more than four days.
29// This shouldn't prune anything, because the timestamp has been updated, so
30// the pruning mechanism won't fire.
Ben Langmuirbeee15e2014-04-14 18:00:01 +000031// RUN: find %t -name DependsOnModule*.pcm | xargs touch -a -t 201101010000
Douglas Gregor527b1c92013-03-25 21:19:16 +000032// RUN: %clang_cc1 -fmodules -F %S/Inputs -fmodules-cache-path=%t -fmodules -fmodules-prune-interval=172800 -fmodules-prune-after=345600 %s -verify
33// RUN: ls %t | grep modules.timestamp
Ben Langmuirbeee15e2014-04-14 18:00:01 +000034// RUN: ls -R %t | grep ^Module.*pcm
35// RUN: ls -R %t | grep DependsOnModule.*pcm
Douglas Gregor527b1c92013-03-25 21:19:16 +000036
37// Set both timestamp and DependsOnModule.pcm back beyond the cutoff.
38// This should trigger pruning, which will remove DependsOnModule but not Module.
Douglas Gregor1f37ddd2013-03-25 21:27:57 +000039// RUN: touch -m -a -t 201101010000 %t/modules.timestamp
Ben Langmuirbeee15e2014-04-14 18:00:01 +000040// RUN: find %t -name DependsOnModule..pcm | xargs touch -a -t 201101010000
Douglas Gregor527b1c92013-03-25 21:19:16 +000041// RUN: %clang_cc1 -fmodules -F %S/Inputs -fmodules-cache-path=%t -fmodules -fmodules-prune-interval=172800 -fmodules-prune-after=345600 %s -verify
42// RUN: ls %t | grep modules.timestamp
Ben Langmuirbeee15e2014-04-14 18:00:01 +000043// RUN: ls -R %t | grep ^Module.*pcm
44// RUN: ls -R %t | not grep DependsOnModule.*pcm
Douglas Gregor527b1c92013-03-25 21:19:16 +000045
46// expected-no-diagnostics