Ticket #705: tests.txt

File tests.txt, 32.0 KB (added by kevan, at 2009-07-20T04:12:02Z)
Line 
1Sun Jul 19 20:45:53 PDT 2009  kevan@isnotajoke.com
2  * Add tests for tahoe mv help text
3
4Sun Jul 19 20:46:09 PDT 2009  kevan@isnotajoke.com
5  * Add tests for tahoe mv behavior
6
7New patches:
8
9[Add tests for tahoe mv help text
10kevan@isnotajoke.com**20090720034553
11 Ignore-this: deb3b6f00b635ea1985c2ba9d68a715
12] hunk ./src/allmydata/test/test_cli.py 394
13     def test_mv(self):
14         help = str(cli.MvOptions())
15         self.failUnless("mv FROM TO" in help, help)
16+        self.failUnless("Use 'tahoe mv' to move files" in help)
17 
18     def test_ln(self):
19         help = str(cli.LnOptions())
20[Add tests for tahoe mv behavior
21kevan@isnotajoke.com**20090720034609
22 Ignore-this: 9f20cc5c19ded743c4b129cdf16e04d9
23] hunk ./src/allmydata/test/test_cli.py 792
24         d.addCallback(_check3)
25         return d
26 
27+class Mv(GridTestMixin, CLITestMixin, unittest.TestCase):
28+    def test_mv_behavior(self):
29+        self.basedir = "cli/Mv/mv_behavior"
30+        self.set_up_grid()
31+        fn1 = os.path.join(self.basedir, "file1")
32+        DATA1 = "Nuclear launch codes"
33+        open(fn1, "wb").write(DATA1)
34+        fn2 = os.path.join(self.basedir, "file2")
35+        DATA2 = "UML diagrams"
36+        open(fn2, "wb").write(DATA2)
37+        # copy both files to the grid
38+        d = self.do_cli("create-alias", "tahoe")
39+        d.addCallback(lambda res:
40+            self.do_cli("cp", fn1, "tahoe:"))
41+        d.addCallback(lambda res:
42+            self.do_cli("cp", fn2, "tahoe:"))
43+        # do mv file1 file3
44+        # (we should be able to rename files)
45+        d.addCallback(lambda res:
46+            self.do_cli("mv", "tahoe:file1", "tahoe:file3"))
47+        d.addCallback(lambda (rc, out, err):
48+            self.failUnlessIn("OK", out, "mv didn't rename a file"))
49+        # do mv file3 file2
50+        # (This should succeed without issue)
51+        d.addCallback(lambda res:
52+            self.do_cli("mv", "tahoe:file3", "tahoe:file2"))
53+        # Out should contain "OK" to show that the transfer worked.
54+        d.addCallback(lambda (rc,out,err):
55+            self.failUnlessIn("OK", out, "mv didn't output OK after mving"))
56+        # Next, make a remote directory.
57+        d.addCallback(lambda res:
58+            self.do_cli("mkdir", "tahoe:directory"))
59+        # mv file2 directory
60+        # (should fail with a descriptive error message; the CLI mv
61+        #  client should support this)
62+        d.addCallback(lambda res:
63+            self.do_cli("mv", "tahoe:file2", "tahoe:directory"))
64+        d.addCallback(lambda (rc, out, err):
65+            self.failUnlessIn(
66+                "Error: You can't overwrite a directory with a file", err,
67+                "mv shouldn't overwrite directories" ))
68+        # mv file2 directory/
69+        # (should succeed by making file2 a child node of directory)
70+        d.addCallback(lambda res:
71+            self.do_cli("mv", "tahoe:file2", "tahoe:directory/"))
72+        # We should see an "OK"...
73+        d.addCallback(lambda (rc, out, err):
74+            self.failUnlessIn("OK", out,
75+                            "mv didn't mv a file into a directory"))
76+        # ... and be able to GET the file
77+        d.addCallback(lambda res:
78+            self.do_cli("get", "tahoe:directory/file2", self.basedir + "new"))
79+        d.addCallback(lambda (rc, out, err):
80+            self.failUnless(os.path.exists(self.basedir + "new"),
81+                            "mv didn't write the destination file"))
82+        # ... and not find the file where it was before.
83+        d.addCallback(lambda res:
84+            self.do_cli("get", "tahoe:file2", "file2"))
85+        d.addCallback(lambda (rc, out, err):
86+            self.failUnlessIn("404", err,
87+                            "mv left the source file intact"))
88+        # Let's build:
89+        # directory/directory2/some_file
90+        # directory3
91+        d.addCallback(lambda res:
92+            self.do_cli("mkdir", "tahoe:directory/directory2"))
93+        d.addCallback(lambda res:
94+            self.do_cli("cp", fn2, "tahoe:directory/directory2/some_file"))
95+        d.addCallback(lambda res:
96+            self.do_cli("mkdir", "tahoe:directory3"))
97+        # Let's now try to mv directory/directory2/some_file to
98+        # directory3/some_file
99+        d.addCallback(lambda res:
100+            self.do_cli("mv", "tahoe:directory/directory2/some_file",
101+                        "tahoe:directory3/"))
102+        # We should have just some_file in tahoe:directory3
103+        d.addCallback(lambda res:
104+            self.do_cli("get", "tahoe:directory3/some_file", "some_file"))
105+        d.addCallback(lambda (rc, out, err):
106+            self.failUnless("404" not in err,
107+                              "mv didn't handle nested directories correctly"))
108+        d.addCallback(lambda res:
109+            self.do_cli("get", "tahoe:directory3/directory", "directory"))
110+        d.addCallback(lambda (rc, out, err):
111+            self.failUnlessIn("404", err,
112+                              "mv moved the wrong thing"))
113+        return d
114+
115 class Cp(GridTestMixin, CLITestMixin, unittest.TestCase):
116 
117     def test_not_enough_args(self):
118
119Context:
120
121[directories: minor change: fix warning message from the benchmarking script
122zooko@zooko.com**20090720002114
123 Ignore-this: 89498e477a70fe9f7d204b592c81785e
124]
125[Add unit tests for the Adder in dirnode.py
126kevan@isnotajoke.com**20090718195049
127 Ignore-this: 93434af3656249962cf9bc6d7ac5bc01
128]
129[Add 'only_files' option to the overwrite field in Adder
130kevan@isnotajoke.com**20090718030010
131 Ignore-this: 56605f6740f692549acdd9b236ce6443
132]
133[rename NewDirectoryNode to DirectoryNode, NewDirectoryURI to DirectoryURI
134Brian Warner <warner@lothar.com>**20090717221549
135 Ignore-this: 5e6226e8d9fba824bf45f67ea5821e0e
136]
137[interfaces: remove dead code, FileNode_ and EncryptedThing constraints
138Brian Warner <warner@lothar.com>**20090717221139
139 Ignore-this: d4faaa37a6d9fbc70e40c43067385582
140]
141[introduction/storage-broker: add assertions of serverids being the right type and of internal consistency between the number of storage servers known and the number of storage servers
142zooko@zooko.com**20090717135221
143 Ignore-this: a315123bcea8eb0eb13172b0919d8753
144]
145[upload: fix #758 recursion-loop in peer-selection when servers report errors.
146Brian Warner <warner@lothar.com>**20090717050709
147 Ignore-this: 9c28ef13649c4475ede23815b69e51fd
148 The bug was in the code that handles a third-or-later pass, and was
149 previously untested.
150]
151[setup: clarify the way that we host two directories of dependencies: one is source distributions and the other is binary distributions
152zooko@zooko.com**20090716160657
153 Ignore-this: 500ef010bc7163ecff86b36461057835
154]
155['tahoe stats': tolerate empty directories. Closes #693.
156Brian Warner <warner@lothar.com>**20090715075109
157 Ignore-this: a713325132e05d5d122111f978fe5e14
158]
159[node.py: record pid in twisted log at startup. Closes #476.
160Brian Warner <warner@lothar.com>**20090715072929
161 Ignore-this: c9054bbf0e114659ac49419e7c658ab6
162]
163[Allow tests to pass with -OO by turning some AssertionErrors (the ones that
164Brian Warner <warner@lothar.com>**20090715064510
165 Ignore-this: db08d38b720a5260b5d1dc6d6a9878c1
166 we actually exercise during tests) into more specific exceptions, so they
167 don't get optimized away. The best rule to follow is probably this: if an
168 exception is worth testing, then it's part of the API, and AssertionError
169 should never be part of the API. Closes #749.
170]
171[setup: tell build to search a directory (hosted on allmydata.org) which contains eggs
172zooko@zooko.com**20090715025246
173 Ignore-this: 1fb41208f777862cc387c3995b01acc
174]
175[wui: fix test for welcome page
176zooko@zooko.com**20090715033429
177 Ignore-this: b36d18be67d873b6d59cd11a849ae627
178]
179[wui: adjust headers/titles and "Attach something to this directory" text in accordance with #691
180zooko@zooko.com**20090715025814
181 Ignore-this: b7ab31947bdadc8c7c56f5037275de71
182 Also name it as "TahoeLAFS" in this text.
183]
184[mac: emit the stdout and stderr from a failed call to Allmydata (this is very useful diagnostic info)
185zooko@zooko.com**20090715014338
186 Ignore-this: f34de1aabfc94026fc6ecdaf92748342
187]
188[mac: improve shutdown and clean-up after the test of the macintosh packaging
189zooko@zooko.com**20090714122655
190 Ignore-this: f2ba2ca7d16173c8c45a9a1411d419c
191]
192[setup: add "test_mac_diskimage" command which attempts to mount and use a .dmg to make sure it has a good Tahoe distribution in it
193zooko@zooko.com**20090712230940
194 Ignore-this: e889aaf49699429afeb211f7403fec74
195]
196[dirnode: finish renaming "iv" to "salt" in the code and the hash tag
197zooko@zooko.com**20090713001320
198 Ignore-this: 10e41a10934f9748fd55b68f54779824
199]
200[dirnode.py/_encrypt_rwcap: rename IV to "salt", which is more accurate
201Brian Warner <warner@lothar.com>**20090712235025
202 Ignore-this: 1b8d6a4e8667655f52abe2b3be46a0ed
203]
204[dirnode.py: security bug: also use child writecap to derive child enc key,
205Brian Warner <warner@lothar.com>**20090712234750
206 Ignore-this: 13867ebc123b521df60e4013b75716e
207 not just the dirnode writecap. The previous code (which only hashed the
208 dirnode writecap) would use the same key for all children, which is very bad.
209 This is the correct implementation of #750.
210]
211[NEWS: update with all recent changes
212Brian Warner <warner@lothar.com>**20090711234703
213 Ignore-this: 8d96344b0e4634186a63b4a8941254a1
214]
215[proposed/mutable-DSA.txt: add some new design criteria
216Brian Warner <warner@lothar.com>**20090711132500
217 Ignore-this: d7519fd9bbcadc331f9843c33dce0d44
218]
219[Use CachingDict instead of dict in dirnode.py
220kevan@isnotajoke.com**20090704034301
221 Ignore-this: 53f12260176a5170b3599eda54f38e98
222]
223[directories: fix semantic conflict between my "keep track of position" optimization patch and Kevan's "cache serialized entries" optimization patch
224zooko@zooko.com**20090710032028
225 Ignore-this: 46f8b00fd3eca4adf89dec437e65d696
226]
227[Modify bench_dirnode.py to use CachingDict.
228kevan@isnotajoke.com**20090705223142
229 Ignore-this: 9ba62a16fd37ef281368715a887fd9f8
230]
231[Add tests for CachingDict, _pack_contents, _unpack_contents
232kevan@isnotajoke.com**20090704034328
233 Ignore-this: 12f3e989244288c211ba393d3a205111
234]
235[trivial: removed unused import noticed by pyflakes
236zooko@zooko.com**20090709130513
237 Ignore-this: 63257c9e8481fdcf617f04cc48d95d03
238]
239[directories: make the IV for the writecaps in directory entries be computed from the secure hash of the writecap itself
240zooko@zooko.com**20090705024815
241 Ignore-this: cb9cc29f8f0687f2545e95d5b7b42d44
242 This makes encoding of directory entries deterministic, and it is also a tad faster on Macbook Pro than getting a random IV with os.urandom(16).
243]
244[tests: raise the timeout on pollmixin from 100s to 1000s -- it looks like it may have triggered too eagerly on Zandr's 266 MHz armel
245zooko@zooko.com**20090709044729
246 Ignore-this: 838b870798dc0f793979398ed4a18c2e
247]
248[setup: add sys.maxunicode to the show-tool-versions output in order to investigate http://bugs.python.org/setuptools/issue78
249zooko@zooko.com**20090709004533
250 Ignore-this: dce4420d5c626258e1033d924e506de2
251]
252[immutable: base32-encode the keys to generate cache filenames that will work on all platforms
253zooko@zooko.com**20090708152633
254 Ignore-this: 782b615c4c35629fee618b39a7175321
255]
256[directories: make initialization of the download cache lazy
257zooko@zooko.com**20090708004040
258 Ignore-this: 3c3714ccc09ae1de811664d52211e143
259 If you open up a directory containing thousands of files, it currently computes the cache filename and checks for the cache file on disk immediately for each immutble file in that directory.  With this patch, it delays those steps until you try to do something with an immutable file that could use the cache.
260]
261[Add CachingDict dict subclass to dirnode.py
262kevan@isnotajoke.com**20090705212345
263 Ignore-this: 484bdcecbc1ae25e04bf659abcfcf834
264]
265[directories: rename internal data member download_cache to download_cache_dirman (benchmarks set this internal member and use the new name, so changing this makes the bench_dirnode.py work again)
266zooko@zooko.com**20090707143404
267 Ignore-this: c77f189a864d517c28a54a4cfce8c0a2
268]
269[directories: keep track of your position as you decode netstring after netstring from an input buffer instead of copying the trailing part
270zooko@zooko.com**20090705025109
271 Ignore-this: bee1ae76060fbc920bddb6e839b7dd1a
272 This makes decoding linear in the number of netstrings instead of O(N^2).
273]
274[directories: in bench_dirnode.py, use a real CacheDirectoryManager instead of a fake one (because CacheDirectoryManager is a significant user of CPU and/or time)
275zooko@zooko.com**20090707034119
276 Ignore-this: 207a2dc346ca2c01dc7b341e88a0ca0a
277]
278[directories: make the profiling behavior of bench_dirnode.py accessible by adding '--profile' to the cmdline
279zooko@zooko.com**20090707033035
280 Ignore-this: 159c36ac1cafaa4e9a6239025ef9d57b
281]
282[setup: increase requirement on pycryptopp to >= 0.5.15
283zooko@zooko.com**20090706140815
284 Ignore-this: f3839c7c1f9ebff1fcf2eea47ed3c48b
285]
286[directories: update the directory benchmarks to exercise the unpack-and-repack functionality, and add optional profiling
287zooko@zooko.com**20090705162953
288 Ignore-this: 4a1b11c9b1880772c923b3c03e10770b
289]
290[test/benchmark: benchmark the time to pack and unpack dirnodes
291zooko@zooko.com**20090704224300
292 Ignore-this: cd8f6a6ded44a3f6f102f9cd0b60ca62
293 See also the prof_benchmarks() function in this file which will run the benchmarks under profiling.
294]
295[setup: the mac-exe build (using py2app) requires macholib>=1.2.
296zooko@zooko.com**20090703175702
297 Ignore-this: ea489a5076f2c9f20f6bfd2807cc5680
298 Here is someone else's description of this problem:
299 http://rtmpy.org/ticket/7
300]
301[clean up debian packaging: we have control files for etch/lenny/sid, and
302"Brian Warner <warner@lothar.com>"**20090703072804
303 everything else uses one of those. Add dependency on python-pysqlite2 for
304 platforms that use py2.4 by default. Update foolscap dependency to 0.4.1.
305]
306[update NEWS to cover all recent changes, sort by end-user importance
307Brian Warner <warner@lothar.com>**20090703014303
308 Ignore-this: 6ddac78075d7547a19712d505818949c
309]
310[Tolerate unknown URI types in directory structures. Part of #683.
311Brian Warner <warner@lothar.com>**20090703010749
312 Ignore-this: afd0e15e2e39d3b87743ec7ccd87054d
313 
314 The idea is that future versions of Tahoe will add new URI types that this
315 version won't recognize, but might store them in directories that we *can*
316 read. We should handle these "objects from the future" as best we can.
317 Previous releases of Tahoe would just explode. With this change, we'll
318 continue to be able to work with everything else in the directory.
319 
320 The code change is to wrap anything we don't recognize as an UnknownNode
321 instance (as opposed to a FileNode or DirectoryNode). Then webapi knows how
322 to render these (mostly by leaving fields blank), deep-check knows to skip
323 over them, deep-stats counts them in "count-unknown". You can rename and
324 delete these things, but you can't add new ones (because we wouldn't know how
325 to generate a readcap to put into the dirnode's rocap slot, and because this
326 lets us catch typos better).
327]
328[test_client.py: minor refactoring of BASECONFIG usage
329Brian Warner <warner@lothar.com>**20090703005450
330 Ignore-this: bf19b9ae7edeab293068cce2368f9364
331]
332[create_node_from_uri: take both writecap+readcap, move logic out of dirnode.py
333Brian Warner <warner@lothar.com>**20090702222537
334 Ignore-this: 93051498076e90d3f1dc85161ce8247a
335]
336[dirnode.py: prepare to preserve both rwcap+rocap when copying
337Brian Warner <warner@lothar.com>**20090702211254
338 Ignore-this: f128c02da32f86d7e39527a35dfc2e02
339 
340 This will make it easier to tolerate unknown nodes safely.
341]
342[interfaces.py: wrap some lines to 80cols
343Brian Warner <warner@lothar.com>**20090702015728
344 Ignore-this: e2c777c1e89a684b43ceabeb0042456c
345]
346[cli: webopen: when called with no arguments, open the Welcome page
347Brian Warner <warner@lothar.com>**20090701200548
348 Ignore-this: ae7d6cb42165d0c751926065378343dd
349]
350[mutable repairer: skip repair of readcaps instead of throwing an exception.
351Brian Warner <warner@lothar.com>**20090701011343
352 Ignore-this: 2c24493426cdc1db8f0e3815ee2c5f87
353 This should improve the behavior of #625 a bit: at least all the files will
354 get repaired.
355]
356[interfaces.py: improve ICheckAndRepairResults docs a bit
357Brian Warner <warner@lothar.com>**20090701001925
358 Ignore-this: 3a57acfee3487c1e071e135743e42c2a
359]
360[repairer.py: wrap to 80cols. No code changes.
361Brian Warner <warner@lothar.com>**20090701000047
362 Ignore-this: 4a84ac95a849be0656d362882876082a
363]
364[setup: require pycryptopp>=0.5.14 if on Windows and with Python>=2.6
365zooko@zooko.com**20090630184807
366 Ignore-this: f7e9beeb5d5613a7c0ffed14d1dda3c6
367]
368[edit NEWS
369Brian Warner <warner@lothar.com>**20090630174115
370 Ignore-this: c4461a2304fcd45bee95e11418693a18
371]
372[NEWS: list all user-visible changes since 1.4.1 . Needs lots of editing.
373Brian Warner <warner@lothar.com>**20090630170734
374 Ignore-this: f606a5d678d0db8065b9f84e796d59b0
375]
376[* find-trailing-spaces.py: exit rc=1 if whitespace found, to be a pre-commit hook
377Brian Warner <warner@lothar.com>**20090629224658
378 Ignore-this: 1465becc923ee04d170e5ee791cf605e
379]
380[use 522-bit RSA keys in all unit tests (except one)
381Brian Warner <warner@lothar.com>**20090629223124
382 Ignore-this: 7a4c3685683ff9da5ceb2d8cb7b19b7
383 
384 This reduces the total test time on my laptop from 400s to 283s.
385 * src/allmydata/test/test_system.py (SystemTest.test_mutable._test_debug):
386   Remove assertion about container_size/data_size, this changes with keysize
387   and was too variable anyways.
388 * src/allmydata/mutable/filenode.py (MutableFileNode.create): add keysize=
389 * src/allmydata/dirnode.py (NewDirectoryNode.create): same
390 * src/allmydata/client.py (Client.DEFAULT_MUTABLE_KEYSIZE): add default,
391   this overrides the one in MutableFileNode
392]
393[remove trailing whitespace
394Brian Warner <warner@lothar.com>**20090629200358
395 Ignore-this: 7a3756618dcfca0a40acb4c3d15f6440
396]
397[remove trailing whitespace from some util classes
398Brian Warner <warner@lothar.com>**20090629200341
399 Ignore-this: ded84c38885d6aabf2691957dde82bf3
400]
401[repairer: raise a better exception when faced with a readonly filenode. Still
402Brian Warner <warner@lothar.com>**20090626063230
403 Ignore-this: a100005b973a6a57566b943073352828
404 produces an error, though.
405]
406[mutable/filenode.py: set _writekey to None, rather than leaving it missing
407Brian Warner <warner@lothar.com>**20090626062022
408 Ignore-this: be111c37dabd6c7aa47abd7bf160926e
409 
410 This will at least turn the really really weird error when a repair of a
411 readonly mutable file is attempted into a merely really weird assertion that
412 mentions "repair currently requires a writecap".
413]
414[one last tweak
415Brian Warner <warner@lothar.com>**20090626052627
416 Ignore-this: 8d9d045a1ebe774aeed6f7e1cdd36973
417]
418[more 'tahoe cp' docs tweaks
419Brian Warner <warner@lothar.com>**20090626051652
420 Ignore-this: f594c395007af64da3d7302943ef8855
421]
422[cli.py: minor tweaks to test posthooks
423"Brian Warner <warner@lothar.com>"**20090626024557]
424[cli.py: update comments on 'tahoe cp' --help a bit
425Brian Warner <warner@lothar.com>**20090626023837
426 Ignore-this: 4090b06896542fbf260d808e8a991cea
427]
428[cli: add some --help text to 'tahoe cp'
429warner@lothar.com**20090625235751]
430[make it possible to add/renew-lease from the WUI
431Brian Warner <warner@lothar.com>**20090626061824
432 Ignore-this: 6fb6a0e8ecfc630464ac37a779078e5
433 add add/renew-lease checkbox on the "more info" page check/deep-check forms
434]
435[hush pyflakes
436warner@lothar.com**20090625021809]
437[Split out NoSharesError, stop adding attributes to NotEnoughSharesError, change humanize_failure to include the original exception string, update tests, behave better if humanize_failure fails.
438warner@lothar.com**20090625021707]
439[remove introducer/old.py, will create something similar when the RIIntroducer changes
440warner@lothar.com**20090624194038]
441[Basically just a trivial platform detection patch for NetBSD.
442midnightmagic@example.com**20090617233647]
443[check_grid.py: print stderr when a subcommand fails
444warner@lothar.com**20090623022833]
445[big rework of introducer client: change local API, split division of responsibilites better, remove old-code testing, improve error logging
446warner@lothar.com**20090623021047]
447[web/welcome.xhtml: remove trailing whitespace
448warner@lothar.com**20090623020909]
449[rrefutil: add trap_deafref utility, to make the callRemote-plus-ignore-DeadReferenceError-plug-log-other-errors pattern easier
450warner@lothar.com**20090623020826]
451[PollMixin: snoop trial's error observer to halt the test early if an error is seen. This turns a lot of timeouts into fast failures.
452warner@lothar.com**20090623020731]
453[clean up storage_broker interface: should fix #732
454warner@lothar.com**20090621235119
455 Ignore-this: fb93cd670e809eed2bc123142dd8d4ff
456]
457[hush pyflakes with recent FileTooLarge removal
458warner@lothar.com**20090621231757
459 Ignore-this: 4231b38c7e9091b0577b07ec99ac2df0
460]
461[add docs/proposed/GridID.txt (cleaning out some of my old branches)
462warner@lothar.com**20090621191204]
463[docs: remove warning about inability to build modules on py2.6 on Windows with mingw, differentiate between clients and servers, reflow to a consistent column width (79), add hint about firewall/NAT docs.
464zooko@zooko.com**20090621175005
465 Ignore-this: 85e7c1ccb258317ca4dd37917afb48f5
466]
467[setup: copy in misc/show-tools-version.py from zfec -- it prints out platform and setuptools versions
468zooko@zooko.com**20090621055846
469 Ignore-this: 4e144886ab02414bbaaf0295ce2b337
470]
471[docs: start updating the NEWS and relnotes.txt files, add Kevan to CREDITS
472zooko@zooko.com**20090621055114
473 Ignore-this: 35e05a5739549ffa693d55df51ffcfd
474]
475[change max filesize limit tests
476kevan@isnotajoke.com**20090620212822
477 Ignore-this: 38e7c62a308c3c93e79df4bf72f4f675
478 
479 Instead of testing to see that the previous SDMF filesize limit was being
480 obeyed, we now test to make sure that we can insert files larger than that
481 limit.
482]
483[remove upper limit on SDMF filesize
484kevan@isnotajoke.com**20090620213130
485 Ignore-this: 5bc48c7421c73827909a17e651799d0c
486]
487[immutable/download: instrument do-you-have-block responses to investigate #732
488warner@lothar.com**20090621041209]
489[Makefile: add jaunty support, rearrange debian sections in order of release
490warner@lothar.com**20090618050502]
491[test_util: add known-answer tests for hashutil tags
492warner@lothar.com**20090618045709]
493[tests: bump up a timeout that expired on Zandr's box
494zooko@zooko.com**20090613195703
495 Ignore-this: 853000f43665396b3734a99f72bd472d
496]
497[util: hooray!  A clean implementation of this simple utility!  Black Dew pointed out that the inverse of time.gmtime() is hidden in the "calendar" module.
498zooko@zooko.com**20090613160112
499 Ignore-this: 8359cc48ca1b8e2793e8b2afe2050cf4
500]
501[util: Brian's horrible hack to figure out how much localtime and utctime differ.  Now we'll see if it works on Windows.
502zooko@zooko.com**20090612204556
503 Ignore-this: 8c36431da4707da76472956c7750ecbd
504]
505[util: oops, time.tzset() doesn't work on Windows -- hopefully the new "London" unit test passes on Windows when we skip tzset() on platforms that don't have it
506zooko@zooko.com**20090612000920
507 Ignore-this: 7d314b8334cfa3f65f9635e3d3eb727e
508]
509[setup: edit install.html to warn Windows users away from Python v2.6
510zooko@zooko.com**20090611225506
511 Ignore-this: 89ad63eab49ede883ef92f2de5b5fc54
512]
513[util: fix time_format.iso_utc_time_to_seconds() so that it works even in London
514zooko@zooko.com**20090611221129
515 Ignore-this: 14dbb9840587797f848226fdb3645c08
516]
517[setup: run the same "make quicktest" on Windows as on non-Windows
518zooko@zooko.com**20090611193214
519 Ignore-this: d0c78377d3892373ec3d91e9e98bd8bd
520 I checked and it behaves about as well on Windows as the previous version did.
521]
522[tests: significantly increase timeouts that triggered on Zandr's ARM box
523zooko@zooko.com**20090610161043
524 Ignore-this: 2b3c556c5166a8267b4b15664d3aadfb
525]
526[test: multiple by 10 or so all timeouts that Zandr's ARM box just overran
527zooko@zooko.com**20090610125639
528 Ignore-this: bf62f063ab46814fd78de55a5fbc9d84
529]
530[tests: bump up timeout on a test that timed out on draco
531zooko@zooko.com**20090610044628
532 Ignore-this: f598b98cbae44dc947937c6ca54c10cb
533]
534[tests: raise the timeout for test_cli since Zandr's ARM machine totally burst through the old one
535zooko@zooko.com**20090609210509]
536[test_cli.Backup: increase timeout massively, it takes 1200s on zandr's ARM linkstation
537warner@lothar.com**20090609052801]
538[tests: double the timeouts on some tests which time-out on Francois's box
539zooko@zooko.com**20090609021753
540 Ignore-this: b2727b04402f24a9b9123d2f84068106
541]
542[tests: bump up timeouts so that the tests can finish before timeout on Francois's little arm box
543zooko@zooko.com**20090608225557
544 Ignore-this: fb83698338b2f12546cd3e1dcb896d34
545]
546[tests: increase timeouts on some other tests that timed-out on Francois's arm box
547zooko@zooko.com**20090605143437
548 Ignore-this: 2903cc20d914fc074c8d7a6c47740ba6
549]
550[tests: bump up the timeout on a bunch of tests that took longer than the default timeout (120s) on François Lenny-armv5tel
551zooko@zooko.com**20090605031444
552 Ignore-this: 84d67849b1f8edc88bf7001e31b5f7f3
553]
554[backup: remove the --no-backupdb command, the handling of "can't import sqlite", and the related tests, and change an error message to more correctly indicate failure to load the database from disk rather than failure to import sqlite module
555zooko@zooko.com**20090604173131
556 Ignore-this: 8200a9fdfc49243c280ecd1d0c44fa19
557 Fixes #728.
558]
559[setup: require pysqlite >= v2.0.5. if we are running on Python < 2.5
560zooko@zooko.com**20090604154548
561 Ignore-this: cf04f46079821df209d01dad2e24b40b
562]
563[setup: add pysqlite and sqlite to get_package_versions()
564zooko@zooko.com**20090604153728
565 Ignore-this: a1dea7fabeab2b08fb0d8d462facdb4d
566]
567[more refactoring: move get_all_serverids() and get_nickname_for_serverid() from Client to storage_broker
568warner@lothar.com**20090602030750]
569[more storage_broker refactoring: downloader gets a broker instead of a client,
570warner@lothar.com**20090602022511
571 use Client.get_storage_broker() accessor instead of direct attribute access.
572]
573[test_runner.py: remove test_client_no_noise: the issue in question is
574warner@lothar.com**20090601225007
575 ticketed in http://divmod.org/trac/ticket/2830 and doesn't need a Tahoe-side
576 change, plus this test fails on win32 for unrelated reasons (and test_client
577 is the place to think about the win32 issue).
578]
579[remove plaintext-hashing code from the helper interface, to close #722
580warner@lothar.com**20090601224916
581 and deny the Helper the ability to mount a partial-information-guessing
582 attack. This will probably break compatibility between new clients and very
583 old (pre-1.0) helpers.
584]
585[start to factor server-connection-management into a distinct 'StorageServerFarmBroker' object, separate from the client and the introducer. This is the starting point for #467: static server selection
586warner@lothar.com**20090601210604]
587[mutable: catch and display first error, so code bugs which break all servers get displayed better
588warner@lothar.com**20090601210407]
589[misc/run-with-pythonpath.py: exec() the child (on unix), to remove the intermediate process
590warner@lothar.com**20090601210137]
591[docs: small edit to about.html
592zooko@zooko.com**20090528233422
593 Ignore-this: 1cfbb1f8426ed6d63b2d3952e4464ddc
594]
595[docs: add links to Tahoe-LAFS for Paranoids and Tahoe-LAFS for Corporates in about.html
596zooko@zooko.com**20090528232717
597 Ignore-this: 7b70baa700d6b6f6e9ceec4132efe5
598]
599[docs: edit about.html and include network-and-reliance-topology.png (loaded from http://allmydata.org )
600zooko@zooko.com**20090527150916
601 Ignore-this: 44adc61cde8ced8be2f0a7dfc7d95dad
602]
603[docs: a few more edits to network-and-reliance-topology.svg
604zooko@zooko.com**20090527150458
605 Ignore-this: 2eac8c33fe71be25ff809b399c6193c1
606]
607[docs: update network-and-reliance-topology.svg for beauty and clarity
608zooko@zooko.com**20090527031123
609 Ignore-this: 5510914849771900ac29b4312470d84
610]
611[docs: update NEWS, relnotes.txt, CREDITS to mention WUI Style
612zooko@zooko.com**20090526233654
613 Ignore-this: 72d16ec833bc4a22af23d29ea1d5ff8b
614]
615[Modify markup of Tahoe web pages to be more amenable to styling; some minor changes of wording.
616Kevin Reid <kpreid@mac.com>**20090526232545
617 Ignore-this: 8845937f0df6c7ddc07abe3211428a6f
618]
619[Tweak wording in directory page: not-read-only is "modifiable", mention creating a directory _in this directory_.
620Kevin Reid <kpreid@mac.com>**20090526232414
621 Ignore-this: f006ec52ba2051802e025a60bcface56
622]
623[Comment on duplication of code/markup found during styling project.
624Kevin Reid <kpreid@mac.com>**20090503203442
625 Ignore-this: a4b7f9f0ab57d2c03be9ba761be8d854
626]
627[Add CSS styles to spiff up the Tahoe WUI's appearance, particularly the welcome page and directories.
628Kevin Reid <kpreid@mac.com>**20090503203142
629 Ignore-this: 5c50af241c1a958b5180ef2b6a49f626
630]
631[Link all Tahoe web pages to the /tahoe_css stylesheet which already exists.
632Kevin Reid <kpreid@mac.com>**20090503202533
633 Ignore-this: 2ea8d14d3168b9502cf39d5ea3f2f2a8
634]
635[Fix broken link from Provisioning to Reliability page.
636Kevin Reid <kpreid@mac.com>**20090501191050
637 Ignore-this: 56dc1a5e659b70cc02dc4df7b5d518cd
638]
639[docs: network-and-reliance-topology.svg: nicer server icons, mv out of the "specifications" subdir
640zooko@zooko.com**20090526165842
641 Ignore-this: 8f47ab3a0ab782c1f0d46e10bcaebe5b
642]
643[docs: update network-and-reliance-topology.svg
644zooko@zooko.com**20090526163105
645 Ignore-this: 2b864b4ed8743d4a15dfbb7eff3fa561
646]
647[accounting-overview.txt: more edits
648warner@lothar.com**20090523190359]
649[accounting-overview.txt: small edits
650warner@lothar.com**20090523184011]
651[_auto_deps.py: require foolscap-0.4.1, which adds an important fix for py2.4
652warner@lothar.com**20090523011103]
653[immutable/encode.py: tolerate immediate _remove_shareholder by copying the
654warner@lothar.com**20090522184424
655 landlord list before iterating over it. This can probably only happen in unit
656 tests, but cleaning it up makes certain test failures easier to analyze.
657]
658[switch to using RemoteException instead of 'wrapped' RemoteReferences. Should fix #653, the rref-EQ problem
659warner@lothar.com**20090522004632]
660[switch all foolscap imports to use foolscap.api or foolscap.logging
661warner@lothar.com**20090522003823]
662[_auto_deps.py: bump our foolscap dependency to 0.4.0, since I'm about to start using its new features
663warner@lothar.com**20090522002100]
664[test_runner.py: fix minor typo
665warner@lothar.com**20090520033620]
666[setup: fix bug (wrong import) in error message, as noticed by pyflakes
667zooko@zooko.com**20090519195642
668 Ignore-this: f1b9f8c00b46c1b5f2f20e5fc424f341
669]
670[setup: fix trivial bug in recent patch to test base64.py at startup
671zooko@zooko.com**20090519195129
672 Ignore-this: f6be038f74b53ca69e7109fe34adfbc
673]
674[setup: make Tahoe exit at startup with a useful error message if the base64.py module is buggy (fixes part of #710)
675zooko@zooko.com**20090519194555
676 Ignore-this: aa4d398235ddca8d417d61c9688e154
677]
678[test_introducer.py: add a test for the python2.4.0/2.4.1 bug in base64.b32decode
679warner@lothar.com**20090519034101]
680[immutable WriteBucketProxy: use pipeline to speed up uploads by overlapping roundtrips, for #392
681warner@lothar.com**20090518234422]
682[util/pipeline.py: new utility class to manage size-limited work pipelines, for #392
683warner@lothar.com**20090518234326]
684[docs: add a diagram that I'm about to show to the Boulder Linux Users Group: network-and-reliance-topology.svg
685zooko@zooko.com**20090514232059
686 Ignore-this: 2420c0a7c254c9f0f2349d9130490d33
687]
688[tests: mark test_runner as coded in utf-8 instead of ascii
689zooko@zooko.com**20090507223151
690 Ignore-this: ccf1ba9e5a9b53602701a36f9fdb545e
691]
692[tests: raise timeout on test_runner.RunNode.test_introducer from 120s to 240s, since it hit the 120s time-out on François Lenny-armv5tel
693zooko@zooko.com**20090507215012
694 Ignore-this: ba18fe6832ba255d4971e8f623ed7da5
695]
696[setup: fix comment in setup.py
697zooko@zooko.com**20090507215003
698 Ignore-this: c46ef664630d52733138ef7fbc551c1c
699]
700[docs: how_to_make_a_tahoe_release.txt: a couple of small edits
701zooko@zooko.com**20090507214932
702 Ignore-this: ae92aa835ad369f4b9e6e49d681957a3
703]
704[.darcs-boringfile: also ignore .gitignore
705warner@allmydata.com**20090415210550
706 Ignore-this: d29db314a1e506f6240859559436b4c3
707]
708[.darcs-boringfile: ignore .git, I'm starting to play around with it
709warner@allmydata.com**20090415205929
710 Ignore-this: 89234453516483c9586cd6e1351e88b5
711]
712[fix quicktest: stop using setuptools, add misc/run-with-pythonpath.py, to make it run faster
713warner@lothar.com**20090414201400]
714[TAG allmydata-tahoe-1.4.1
715zooko@zooko.com**20090414025636
716 Ignore-this: de78fc32364c83e9f4e26b5abcfdea4a
717]
718Patch bundle hash:
719c57d6a23e045a1935f9fc09e66e65e58c5cbc302