#include <lwext4/ext4_mkfs.h>
}
#include <boost/filesystem.hpp>
+#include <chrono>
#include <string>
}
}
+
+static
+void
+set_timestamps_to_now (boost::filesystem::path path)
+{
+ auto const now = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now().time_since_epoch()).count();
+ ext4_mtime_set (path.generic_string().c_str(), now);
+ ext4_ctime_set (path.generic_string().c_str(), now);
+ ext4_atime_set (path.generic_string().c_str(), now);
+}
+
+
static
string
write (boost::filesystem::path from, boost::filesystem::path to, uint64_t& total_remaining, uint64_t total, Nanomsg* nanomsg)
ext4_fclose (&out);
delete[] buffer;
+ set_timestamps_to_now (to);
+
return digester.get ();
}
if (r != EOK) {
throw CopyError (String::compose("Failed to create directory %1", cr.generic_string()), r);
}
+ set_timestamps_to_now (cr);
for (directory_iterator i = directory_iterator(from); i != directory_iterator(); ++i) {
copy (i->path(), cr, total_remaining, total, copied_files, nanomsg);
vector<string>
-ext2_ls (string path)
+ext2_ls (vector<string> arguments)
{
using namespace boost::process;
boost::asio::io_service ios;
future<string> data;
- /* e2ls is from 'e2tools */
- child ch (search_path("e2ls"), path, std_in.close(), std_out > data, ios);
+ child ch (search_path("e2ls"), arguments, std_in.close(), std_out > data, ios);
ios.run();
auto output = data.get();
}
-/** Use the writer code to make a disk and partition and copy a file to it, then check
- * that the partition has inode size 128 and that the file can be copied back off using
- * e2tools.
+/** Use the writer code to make a disk and partition and copy a file (in a directory)
+ * to it, then check that:
+ * - the partition has inode size 128
+ * - the file and directory have reasonable timestamps
+ * - the file can be copied back off the disk
*/
BOOST_AUTO_TEST_CASE (disk_writer_test1)
{
BOOST_CHECK_EQUAL (matches[1].str(), "128");
}
- BOOST_CHECK (ext2_ls(partition.string()) == vector<string>({"disk_writer_test1", "lost+found"}));
- BOOST_CHECK (ext2_ls(partition.string() + ":disk_writer_test1") == vector<string>({"foo"}));
+ BOOST_CHECK (ext2_ls({partition.string()}) == vector<string>({"disk_writer_test1", "lost+found"}));
+
+ string const unset_date = "1-Jan-1970";
+
+ /* Check timestamp of the directory has been set */
+ auto details = ext2_ls({"-l", partition.string()});
+ BOOST_REQUIRE (details.size() >= 6);
+ BOOST_CHECK (details[5] != unset_date);
+
+ auto const dir = partition.string() + ":disk_writer_test1";
+ BOOST_CHECK (ext2_ls({dir}) == vector<string>({"foo"}));
+
+ /* Check timestamp of foo */
+ details = ext2_ls({"-l", dir});
+ BOOST_REQUIRE (details.size() >= 6);
+ BOOST_CHECK (details[5] != unset_date);
system ("e2cp " + partition.string() + ":disk_writer_test1/foo build/test/disk_writer_test1_foo_back");
check_file ("build/test/disk_writer_test1/foo", "build/test/disk_writer_test1_foo_back");