| Age | Commit message (Collapse) | Author | 
|---|
|  | If we encounter a 128KB block of zeros, try to skip to the next
data section by calling File.SeekData().
This fixes xfstests generic/285, which creates a 17TB sparse file,
and runs fsck afterwards. Without this optimization, fsck would
take ages. | 
|  | TrezorPayload stores 32 random bytes used for unlocking
the master key using a Trezor security module. The randomness makes sure
that a unique unlock value is used for each gocryptfs filesystem. | 
|  | configfile.LoadConfFile()   -> configfile.Load()
configfile.CreateConfFile() -> configfile.Create() | 
|  | Using an external program for the Trezor PIN is not supported
at the moment. | 
|  | Verify that the Trezor feature flag is set after "-init -trezor". | 
|  | readpassword.Trezor() is not implemented yet and returns
a hardcoded dummy key. | 
|  | When mounted via /etc/fstab like this,
  /a /b fuse.gocryptfs default 0 0
we always get extra options passed. As reported by @mahkoh
at https://github.com/rfjakob/gocryptfs/pull/233 :
  mount passes `-o noexec` if `-o user` is set and `-o exec` is not set.
  If both `-o user` and `-o exec` are set, it passes `-o exec`.
Make these options work, and in addtion, also make -suid and -rw
work the same way.
Reported-by: @mahkoh | 
|  | By returning an error instead of calling os.Exit,
error cases can be tested easily. Error cases
were not tested until now. | 
|  | Support has been merged into the xattr package
( https://github.com/pkg/xattr/pull/29 ), use it. | 
|  | This currently fails because we do not use llistxattr
yet. | 
|  | mv is unhappy when we return EPERM when it tries to set
system.posix_acl_access:
   mv: preserving permissions for ‘b/x’: Operation not permitted
Now we return EOPNOTSUPP like tmpfs does and mv seems happy. | 
|  |  | 
|  | Values a binary-safe, there is no need to base64-encode them.
Old, base64-encoded values are supported transparently
on reading. Writing xattr values now always writes them binary. | 
|  | The tests write to the example_filesystems folder, which
1) May leave your source tree in a modified state
2) Triggers test failures when the fsck tests run concurrently,
   which happens on Travis CI every now and then.
Fix both problem by copying the example_filesystems folder
to a private location in /tmp. | 
|  | These were using stale err values. | 
|  | Reported by https://goreportcard.com/report/github.com/rfjakob/gocryptfs | 
|  | Gnome may still have files open causing spurious test
failures. | 
|  | One fd leak found in TestMountBackground. | 
|  | And fix two in test_helpers.Mount().
Leftover fds can cause an unmount failure like this later:
fusermount: failed to unmount /tmp/gocryptfs-test-parent/873632270/default-plain: Device or resource busy
so try to catch them early. | 
|  | With testcases. | 
|  |  | 
|  | Make sure we get only 1 warning output per
problem.
Also, add new corruption types to broken_fs_v1.4. | 
|  | Most corruption cases except xattr should be covered.
With test filesystem.
The output is still pretty ugly. xattr support will
be added in the next commits. | 
|  | These can cause EBUSY errors when unmounting. | 
|  | The fsck operation is not yet implemented, this commits
just adds the flag and improves cli flag handling. | 
|  | Now that https://github.com/pkg/xattr/pull/24
has been merged there is no reason to keep
our private copy.
Switch to the upstream version. | 
|  | This function has been deprecated by the pkg/xattr
upstream, so write our own. | 
|  | We handle empty files by storing an actual empty file
on disk. Handle xattrs similarily and encrypt the
empty value to the empty value. | 
|  | At the moment, only for reverse mode.
https://github.com/rfjakob/gocryptfs/issues/217 | 
|  | SwitchTestParentDir changes testParentDir. This is used when you want
to perform tests on a special filesystem. For example, the xattr tests
cannot run on tmpfs and use /var/tmp instead of /tmp. | 
|  | https://github.com/rfjakob/gocryptfs/issues/218 | 
|  | macos does not have /proc, so don't try to read it. | 
|  | MacOS does not have it installed by default. | 
|  | Extracting the symlink fails with
	linux-3.0/arch/microblaze/boot/dts/system.dts: Can't set permissions to 0755
so just exclude it.
The ln error Looks scary but is harmless, so get rid of it.
The symlink is only created to make it more convenient to view the
csv log. | 
|  | macos' bash and ln lack a few features we used. | 
|  | Makes the scripts work when wget is not available (macos) | 
|  |  | 
|  | macos does not have lazy unmount, so let's not use it
on linux either.
If the unmount fails, run "lsof" to find the open file.
Also fix the first bug we found this way. | 
|  | Causes "Resource busy" unmount failures on macos | 
|  | Fixes test-without-openssl.bash. | 
|  |  | 
|  | Not supported on macos.
Beef up the first test case a little by using different second
values. | 
|  |  | 
|  | We relied on the finalizer to close a few fds.
For some reason, this did not cause problems on Linux,
but on MacOS, it causes unmount failures:
umount(/private/tmp/gocryptfs-test-parent/194654785/default-plain): Resource busy -- try 'diskutil unmount' | 
|  | Gets rid of the touch error message upon running the tests. | 
|  | Limit is much lower than on linux | 
|  | These cannot work on MacOS. | 
|  | To Go test logic waits for stderr and stdout to close, so
when we share it with a subprocess, it will wait for it to
exit as well.
We don't want the tests to hang when the unmount fails.
Seen on MacOS as reported at
https://github.com/rfjakob/gocryptfs/issues/213 | 
|  | This will allows us to overwrite the password
with zeros once we are done with it.
https://github.com/rfjakob/gocryptfs/issues/211 | 
|  |  |