# This file is part of GNUnet.
# (C) 2010 Christian Grothoff (and other contributing authors)
#
-# GNUnet is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published
-# by the Free Software Foundation; either version 2, or (at your
-# option) any later version.
+# GNUnet is free software: you can redistribute it and/or modify it
+# under the terms of the GNU Affero General Public License as published
+# by the Free Software Foundation, either version 3 of the License,
+# or (at your option) any later version.
#
# GNUnet is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-# General Public License for more details.
+# Affero General Public License for more details.
#
-# You should have received a copy of the GNU General Public License
-# along with GNUnet; see the file COPYING. If not, write to the
-# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-# Boston, MA 02111-1307, USA.
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+# SPDX-License-Identifier: AGPL3.0-or-later
#
# Testcase for file-sharing command-line tools (recursive publishing & download)
-import pexpect
+import sys
import os
-import signal
+import subprocess
import re
+import shutil
+import tarfile
+import filecmp
+
+srcdir = "../.."
+gnunet_pyexpect_dir = os.path.join(srcdir, "contrib/scripts")
+if gnunet_pyexpect_dir not in sys.path:
+ sys.path.append(gnunet_pyexpect_dir)
+
+from gnunet_pyexpect import pexpect
+from pydiffer import dcdiff
+
+if os.name == 'posix':
+ download = './gnunet-download'
+ gnunetarm = 'gnunet-arm'
+ publish = './gnunet-publish'
+ unindex = './gnunet-unindex'
+ search = './gnunet-search'
+ directory = './gnunet-directory'
+elif os.name == 'nt':
+ download = './gnunet-download.exe'
+ gnunetarm = 'gnunet-arm.exe'
+ publish = './gnunet-publish.exe'
+ unindex = './gnunet-unindex.exe'
+ search = './gnunet-search.exe'
+ directory = './gnunet-directory.exe'
+
+if os.name == "nt":
+ shutil.rmtree(os.path.join(os.getenv("TEMP"), "gnunet-test-fs-py-rec"), True)
+else:
+ shutil.rmtree("/tmp/gnunet-test-fs-py-rec", True)
+
+arm = subprocess.Popen([gnunetarm, '-sq', '-c', 'test_gnunet_fs_rec_data.conf'])
+arm.communicate()
-os.system ('rm -rf /tmp/gnunet-test-fs-py-rec/')
-os.system ('gnunet-arm -sq -c test_gnunet_fs_rec_data.conf')
-os.system ('tar xfz test_gnunet_fs_rec_data.tgz')
+# pray that `tar' is in PATH.
+# FIXME: Actually we should check for that and output
+# a message if it isn't found.
+tar = tarfile.open('test_gnunet_fs_rec_data.tgz')
+tar.extractall()
+# first, basic publish-search-download run
try:
- pub = pexpect.spawn ('gnunet-publish -c test_gnunet_fs_rec_data.conf -d -k testdir dir/')
- pub.expect ('Publishing `dir/\' done.\r')
- pub.expect ("URI is `gnunet://fs/chk/CQI091BQ15LLC2NO5RQM2LP95D8I0ONKDFT912V8CMH3BIPDUSDKG3JL07V9E89JPJ0CG5JE9EAQLC1Q6I0VF9L8M86MO0K3DG7HA2O.NVIUL6B7AT6TIUVOV0JLIQ3LLSS3TRLCVAISDS47V0KVHN22TJ9H9247HQNA8T3KK1J32QJ65312DUQPA2EBQPNII279BU0MKJEB94G.20181'.")
- #pub.expect ("URI is `gnunet://fs/chk/8PNDC5FDF7T57HUGM9ODSL7CDKNOLPUFDCJQQ2MPP4SUPSEAJP1LNLBMEFN21KAG0KNVG3LG2AJCV322G3ECU6GKM9HFCVKM78LKEUO.9MI810JGAE6QVQMTBBVO2E92PA3C1MVF511CGKIPBMJ1B0PERIBDK9TNVD2JB4E4NFTD5F8QORJ644CUC281PISDND1NVGC7PB14388.20173'.")
- pub.expect (pexpect.EOF)
-
- down = pexpect.spawn ('gnunet-download -c test_gnunet_fs_rec_data.conf -R -o rdir.gnd gnunet://fs/chk/CQI091BQ15LLC2NO5RQM2LP95D8I0ONKDFT912V8CMH3BIPDUSDKG3JL07V9E89JPJ0CG5JE9EAQLC1Q6I0VF9L8M86MO0K3DG7HA2O.NVIUL6B7AT6TIUVOV0JLIQ3LLSS3TRLCVAISDS47V0KVHN22TJ9H9247HQNA8T3KK1J32QJ65312DUQPA2EBQPNII279BU0MKJEB94G.20181')
- #down = pexpect.spawn ('gnunet-download -c test_gnunet_fs_rec_data.conf -R -o rdir.gnd gnunet://fs/chk/8PNDC5FDF7T57HUGM9ODSL7CDKNOLPUFDCJQQ2MPP4SUPSEAJP1LNLBMEFN21KAG0KNVG3LG2AJCV322G3ECU6GKM9HFCVKM78LKEUO.9MI810JGAE6QVQMTBBVO2E92PA3C1MVF511CGKIPBMJ1B0PERIBDK9TNVD2JB4E4NFTD5F8QORJ644CUC281PISDND1NVGC7PB14388.20173')
-
- down.expect (re.compile ("Downloading `rdir.gnd\' done \(.*\).\r"));
- down.expect (pexpect.EOF);
-
- dir = pexpect.spawn ('gnunet-directory -c test_gnunet_fs_rec_data.conf rdir/a.gnd')
- dir.expect (re.compile (" last: a"));
- dir.expect (re.compile (" last: COPYING"));
-# dir.expect (re.compile (" *embedded filename: a"));
-# dir.expect (re.compile (" *embedded filename: COPYING"));
- dir.expect (pexpect.EOF)
-
- os.system ('rm -r rdir/b.gnd rdir/a.gnd')
- if (0 != os.system ("diff -r dir rdir")):
- raise Exception ("Unexpected difference between source directory and downloaded result")
-
+ pub = pexpect()
+ pub.spawn(None, [publish, '-c', 'test_gnunet_fs_rec_data.conf', '-k', 'testdir', 'dir/'], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
+ # Can't say much for publishing, except that the last one is the toplevel directory
+ pub.expect("stdout", re.compile(r"Publishing `.+' done\.\r?\n"))
+ pub.expect("stdout", re.compile(r"URI is `gnunet://fs/chk/[A-Z0-9]{103}\.[A-Z0-9]{103}\.\d+'\.\r?\n"))
+ pub.expect("stdout", re.compile(r"Publishing `.+' done\.\r?\n"))
+ pub.expect("stdout", re.compile(r"URI is `gnunet://fs/chk/[A-Z0-9]{103}\.[A-Z0-9]{103}\.\d+'\.\r?\n"))
+ pub.expect("stdout", re.compile(r"Publishing `.+' done\.\r?\n"))
+ pub.expect("stdout", re.compile(r"URI is `gnunet://fs/chk/[A-Z0-9]{103}\.[A-Z0-9]{103}\.\d+'\.\r?\n"))
+ pub.expect("stdout", re.compile(r"Publishing `.+' done\.\r?\n"))
+ pub.expect("stdout", re.compile(r"URI is `gnunet://fs/chk/[A-Z0-9]{103}\.[A-Z0-9]{103}\.\d+'\.\r?\n"))
+ pub.expect("stdout", re.compile(r"Publishing `.+' done\.\r?\n"))
+ pub.expect("stdout", re.compile(r"URI is `gnunet://fs/chk/[A-Z0-9]{103}\.[A-Z0-9]{103}\.\d+'\.\r?\n"))
+ pub.expect("stdout", re.compile(r"Publishing `.+' done\.\r?\n"))
+ pub.expect("stdout", re.compile(r"URI is `gnunet://fs/chk/[A-Z0-9]{103}\.[A-Z0-9]{103}\.\d+'\.\r?\n"))
+ pub.expect("stdout", re.compile(r"Publishing `.+[\\/]dir[\\/]' done\.\r?\n"))
+ m = pub.expect("stdout", re.compile(r".+\r?\n"))
+ if not m:
+ sys.exit(3)
+ output = m.string
+ url = output[output.find("`")+1:output.find("'")]
+
+ down = pexpect()
+ down.spawn(None, [download, '-c', 'test_gnunet_fs_rec_data.conf', '-R', '-o', 'rdir.gnd', url], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
+ down.expect("stdout", re.compile(r"Downloading `rdir.gnd' done (.*).\r?\n"))
+
+ d = pexpect()
+ d.spawn(None, [directory, '-c', 'test_gnunet_fs_rec_data.conf', 'rdir/a.gnd'], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
+ d.expect("stdout", re.compile(r"Directory `a/' meta data:\r?\n"))
+ d.expect("stdout", re.compile(r"Directory `a/' contents:\r?\n"))
+ d.expect("stdout", re.compile(r"COPYING (.*)\r?\n"))
+ d.expect("stdout", re.compile(r"INSTALL (.*)\r?\n"))
+
+ os.remove("rdir/b.gnd")
+ os.remove("rdir/a.gnd")
+ diff = dcdiff('dir', 'rdir')
+ if len(diff) != 0:
+ raise Exception("Unexpected difference between source directory and downloaded result:\n{}".format(diff))
+
+
finally:
- os.system ('gnunet-arm -c test_gnunet_fs_rec_data.conf -eq')
- os.system ('rm -r dir rdir rdir.gnd')
- os.system ('rm -rf /tmp/gnunet-test-fs-py-rec/')
+ arm = subprocess.Popen([gnunetarm, '-eq', '-c', 'test_gnunet_fs_rec_data.conf'])
+ arm.communicate()
+ if os.name == "nt":
+ shutil.rmtree(os.path.join(os.getenv("TEMP"), "gnunet-test-fs-py-rec"), True)
+ else:
+ shutil.rmtree("/tmp/gnunet-test-fs-py-rec", True)
+ shutil.rmtree("dir", True)
+ shutil.rmtree("rdir", True)
+ shutil.rmtree("rdir.gnd", True)