forked from ai2cm/pace
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile.data_download
44 lines (36 loc) · 1.72 KB
/
Makefile.data_download
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
44
REGRESSION_DATA_STORAGE_BUCKET = gs://vcm-fv3gfs-serialized-regression-data
ROOT_DIR:=$(shell dirname $(realpath $(firstword $(MAKEFILE_LIST))))
EXPERIMENT ?=c12_6ranks_standard
FORTRAN_SERIALIZED_DATA_VERSION=8.1.3
TARGET ?=dycore
TEST_DATA_ROOT ?=$(ROOT_DIR)/test_data/
TEST_DATA_HOST ?=$(TEST_DATA_ROOT)/$(FORTRAN_SERIALIZED_DATA_VERSION)/$(EXPERIMENT)/$(TARGET)
EXPERIMENT_DATA ?=$(TEST_DATA_ROOT)/$(FORTRAN_SERIALIZED_DATA_VERSION)/$(EXPERIMENT)
FTP_SERVER ?=ftp://anonymous:[email protected]
TEST_DATA_FTP ?=in/put/abc/cosmo/fuo/pace/fv3core/
TEST_DATA_TARFILE=dat_files.tar.gz
TEST_DATA_TARPATH=$(TEST_DATA_HOST)/$(TEST_DATA_TARFILE)
DATA_BUCKET= $(REGRESSION_DATA_STORAGE_BUCKET)/$(FORTRAN_SERIALIZED_DATA_VERSION)/$(EXPERIMENT)/$(TARGET)/
sync_test_data:
mkdir -p $(TEST_DATA_HOST) && gsutil -m rsync -r $(DATA_BUCKET) $(TEST_DATA_HOST)
sync_test_data_from_ftp:
mkdir -p $(TEST_DATA_HOST) && cd $(TEST_DATA_ROOT) && lftp -c "set ftp:list-options -a; open $(FTP_SERVER); cd $(TEST_DATA_FTP); mirror --delete --use-cache --verbose --allow-chown --allow-suid --no-umask --parallel=2 --max-errors=0 . ."
get_test_data:
if [ -z "${USE_FTP}" ] ; then \
if [ ! -f "$(TEST_DATA_HOST)/input.nml" ] || \
[ "$$(gsutil cp $(DATA_BUCKET)md5sums.txt -)" != "$$(cat $(TEST_DATA_HOST)/md5sums.txt)" ] ; then \
rm -rf $(TEST_DATA_HOST) ; \
$(MAKE) sync_test_data ; \
$(MAKE) unpack_test_data ; \
fi ; \
else \
$(MAKE) sync_test_data_from_ftp ; \
$(MAKE) unpack_test_data ; \
fi
unpack_test_data:
if [ -f $(TEST_DATA_TARPATH) ]; then \
cd $(TEST_DATA_HOST) && tar -xf $(TEST_DATA_TARFILE) && \
rm $(TEST_DATA_TARFILE); \
fi
list_test_data_options:
gsutil ls $(REGRESSION_DATA_STORAGE_BUCKET)/$(FORTRAN_SERIALIZED_DATA_VERSION)