--- nsdl/build/Makefile 2002/05/23 19:58:49 1.3 +++ nsdl/build/Makefile 2002/07/14 06:39:06 1.6 @@ -1,7 +1,7 @@ # The NSDL to LON-CAPA Gateway Server # Scott Harrison -# $Id: Makefile,v 1.3 2002/05/23 19:58:49 harris41 Exp $ +# $Id: Makefile,v 1.6 2002/07/14 06:39:06 harris41 Exp $ DISTPROBE=`perl ./distprobe` DIST=$(DISTPROBE) @@ -29,13 +29,13 @@ help: @echo "install: install from a compiled CVS source tree to a " @echo " specified TARGET destination on the filesystem" @echo "test: test different parts of the LON-CAPA system (TEST_*)" - @echo "TEST_lpml_scripts: make sure that the system can process " + @echo "TEST_lpml: make sure that the system can process " @echo " the Linux Packaging Markup Language" @echo "TEST_system_dependencies: make sure that all needed system " @echo " components are active and present " @echo " on the server such as perl modules" @echo " and the MySQL database" - @echo "TEST_web_layer: mimic various web-based interactions with " + @echo "TEST_weblayer: mimic various web-based interactions with " @echo " respect to the login and various system " @echo " actions on the Gateway server" @echo "HTML: generate an HTML-formatted description of the " @@ -54,8 +54,20 @@ help: @echo "tardist: build a tarball that will upgrade the software on a " @echo " system" -build: - @echo "Not yet implemented" +build: Makefile.build + echo -n "" > WARNINGS + make -f Makefile.build all + make warningnote + +Makefile.build: Makefile alwaysrun + cat gatewayfiles.lpml | \ + perl lpml_parse.pl build $(CATEGORY) $(DIST) "$(SOURCE)" \ + "$(TARGET)" > Makefile.build + +NET_install: + make TIMESTAMP=`date +"%s"` METAMTARGET="TRANSPORT" \ + MTARGET="install" HOSTNAME="$(HOSTNAME)" lpmladm + make warningnote install: Makefile.install @echo -n "" > WARNINGS @@ -71,20 +83,25 @@ Makefile.install: Makefile alwaysrun alwaysrun: -test: - @echo "Not yet implemented" +test: TEST_lpml TEST_system_dependencies TEST_weblayer + @echo "ALL TESTS SUCCESSFUL" -TEST_lpml_scripts: - @echo "Not yet implemented" +TEST_lpml: + @echo "TESTING LPML INSTALLATION MECHANISM" + cd lpml_test; perl filecomparetest.pl TEST_system_dependencies: - @echo "Not yet implemented" + @echo "TESTING WEB LAYER" -TEST_web_layer: - @echo "Not yet implemented" +TEST_weblayer: + @echo "TESTING SYSTEM DEPENDENCIES" HTML: - @echo "Not yet implemented" + install -d HTML + cp $(SOURCE)/doc/gatewayfiles/*.gif HTML + cat gatewayfiles.lpml | \ + perl lpml_parse.pl html development default "$(SOURCE)" '$(TARGET)' \ + > HTML/index.html doc: @echo "Not yet implemented" @@ -113,6 +130,39 @@ warningnote: echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"; \ fi +lpmladm: + @if (test $(METAMTARGET) = "TRANSPORT"); then \ + echo "Transporting to $(HOSTNAME)"; \ + sudo mkdir lpmladm.$(TIMESTAMP); \ + sudo make DIST=$(DIST) CATEGORY=$(CATEGORY) \ + SOURCE="$(SOURCE)" \ + TARGET="lpmladm.$(TIMESTAMP)" \ + NORESTORECONF="$(NORESTORECONF)" "$(MTARGET)"; \ + cd lpmladm.$(TIMESTAMP); \ + sudo tar czf ../tarball$(TIMESTAMP).tar.gz .; \ + cd ..; scp tarball$(TIMESTAMP).tar.gz \ + lpmladm@$(HOSTNAME):~/tarball$(TIMESTAMP).tar.gz; \ + sudo rm -Rf lpmladm.$(TIMESTAMP); \ + sudo rm -f tarball$(TIMESTAMP).tar.gz; \ + ssh lpmladm@$(HOSTNAME) sudo mv tarball$(TIMESTAMP).tar.gz /; \ + ssh lpmladm@$(HOSTNAME) sudo tar -x -z -C / \ + -p --same-owner -f \ + /tarball$(TIMESTAMP).tar.gz; \ + ssh lpmladm@$(HOSTNAME) sudo rm -f \ + /tarball$(TIMESTAMP).tar.gz; \ + elif (test $(METAMTARGET) = "LAUNCH"); then \ + echo "Launching process on $(HOSTNAME)"; \ + LAUNCHSAVE=$(OUTSTREAM) $(SAVE); \ + make DIST=$(DIST) CATEGORY=$(CATEGORY) SOURCE="$(SOURCE)" \ + TARGET="$(TARGET)" NORESTORECONF="$(NORESTORECONF)" \ + LAUNCH="$(LAUNCHSAVE)" "$(MTARGET)"; \ + scp $(SAVE) lpmladm@$(HOSTNAME):$(SAVE); \ + ssh lpmladm@$(HOSTNAME) sudo -u $(LAUNCHUSER) perl $(SAVE); \ + else \ + echo "**** ERROR **** Incorrect METAMTARGET"; \ + fi +# ssh lpmladm@$(HOSTNAME) sudo rm -f $(SAVE); \ + clean: @echo "Not yet implemented"