3 # authz_tests.py: testing authentication.
5 # Subversion is a tool for revision control.
6 # See http://subversion.tigris.org for more information.
8 # ====================================================================
9 # Copyright (c) 2000-2006 CollabNet. All rights reserved.
11 # This software is licensed as described in the file COPYING, which
12 # you should have received as part of this distribution. The terms
13 # are also available at http://subversion.tigris.org/license-1.html.
14 # If newer versions of this license are posted there, you may use a
15 # newer version instead, at your option.
17 ######################################################################
25 from svntest
.main
import write_restrictive_svnserve_conf
26 from svntest
.main
import write_authz_file
27 from svntest
.main
import server_authz_has_aliases
30 Item
= svntest
.wc
.StateItem
31 XFail
= svntest
.testcase
.XFail
32 Skip
= svntest
.testcase
.Skip
33 SkipUnless
= svntest
.testcase
.SkipUnless
35 ######################################################################
38 # Each test must return on success or raise on failure.
41 #----------------------------------------------------------------------
43 # regression test for issue #2486 - part 1: open_root
45 def authz_open_root(sbox
):
46 "authz issue #2486 - open root"
50 write_authz_file(sbox
, {"/": "", "/A": "jrandom = rw"})
52 write_restrictive_svnserve_conf(sbox
.repo_dir
)
54 # we have write access in folder /A, but not in root. Test on too
55 # restrictive access needed in open_root by modifying a file in /A
58 mu_path
= os
.path
.join(wc_dir
, 'A', 'mu')
59 svntest
.main
.file_append(mu_path
, "hi")
61 # Create expected output tree.
62 expected_output
= svntest
.wc
.State(wc_dir
, {
63 'A/mu' : Item(verb
='Sending'),
66 # Commit the one file.
67 svntest
.actions
.run_and_verify_commit(wc_dir
,
73 #----------------------------------------------------------------------
75 # regression test for issue #2486 - part 2: open_directory
77 def authz_open_directory(sbox
):
78 "authz issue #2486 - open directory"
82 write_authz_file(sbox
, {"/": "*=rw", "/A/B": "*=", "/A/B/E": "jrandom = rw"})
84 write_restrictive_svnserve_conf(sbox
.repo_dir
)
86 # we have write access in folder /A/B/E, but not in /A/B. Test on too
87 # restrictive access needed in open_directory by moving file /A/mu to
91 mu_path
= os
.path
.join(wc_dir
, 'A', 'mu')
92 E_path
= os
.path
.join(wc_dir
, 'A', 'B', 'E')
94 svntest
.main
.run_svn(None, 'mv', mu_path
, E_path
)
96 # Create expected output tree.
97 expected_output
= svntest
.wc
.State(wc_dir
, {
98 'A/mu' : Item(verb
='Deleting'),
99 'A/B/E/mu' : Item(verb
='Adding'),
102 # Commit the working copy.
103 svntest
.actions
.run_and_verify_commit(wc_dir
,
109 def broken_authz_file(sbox
):
110 "broken authz files cause errors"
112 sbox
.build(create_wc
= False)
114 # No characters but 'r', 'w', and whitespace are allowed as a value
116 write_authz_file(sbox
, {"/": "jrandom = rw # End-line comments disallowed"})
118 write_restrictive_svnserve_conf(sbox
.repo_dir
)
120 exit_code
, out
, err
= svntest
.main
.run_svn(1,
122 sbox
.repo_url
+ "/A",
123 "-m", "a log message");
125 raise svntest
.verify
.SVNUnexpectedStdout(out
)
127 raise svntest
.verify
.SVNUnexpectedStderr("Missing stderr")
129 # test whether read access is correctly granted and denied
130 def authz_read_access(sbox
):
131 "test authz for read operations"
133 sbox
.build(create_wc
= False)
135 root_url
= sbox
.repo_url
136 A_url
= root_url
+ '/A'
140 mu_url
= A_url
+ '/mu'
141 iota_url
= root_url
+ '/iota'
142 lambda_url
= B_url
+ '/lambda'
143 alpha_url
= E_url
+ '/alpha'
146 pi_url
= G_url
+ '/pi'
148 chi_url
= H_url
+ '/chi'
150 if sbox
.repo_url
.startswith("http"):
151 expected_err
= ".*403 Forbidden.*"
153 expected_err
= ".*svn: Authorization failed.*"
155 # create some folders with spaces in their names
156 svntest
.actions
.run_and_verify_svn(None, None, [],
159 B_url
+'/folder with spaces',
160 B_url
+'/folder with spaces/empty folder')
162 write_restrictive_svnserve_conf(sbox
.repo_dir
)
164 write_authz_file(sbox
, { "/": "* = r",
167 "/A/D/G": ("* = rw\n" +
168 svntest
.main
.wc_author
+ " ="),
169 "/A/D/H": ("* = \n" +
170 svntest
.main
.wc_author
+ " = rw"),
171 "/A/B/folder with spaces":
172 (svntest
.main
.wc_author
+ " = r")})
175 svntest
.actions
.run_and_verify_svn(None, ["This is the file 'iota'.\n"],
179 # read a remote file, readably by user specific exception
180 svntest
.actions
.run_and_verify_svn(None, ["This is the file 'chi'.\n"],
184 # read a remote file, unreadable: should fail
185 svntest
.actions
.run_and_verify_svn(None,
190 # read a remote file, unreadable through recursion: should fail
191 svntest
.actions
.run_and_verify_svn(None,
196 # read a remote file, user specific authorization is ignored because * = rw
197 svntest
.actions
.run_and_verify_svn(None, ["This is the file 'pi'.\n"],
200 # open a remote folder(ls)
201 svntest
.actions
.run_and_verify_svn("ls remote root folder",
206 # open a remote folder(ls), unreadable: should fail
207 svntest
.actions
.run_and_verify_svn(None,
208 None, svntest
.verify
.AnyOutput
, 'ls',
211 # open a remote folder(ls) with spaces, should succeed
212 svntest
.actions
.run_and_verify_svn(None,
214 B_url
+'/folder with spaces/empty folder')
216 # open a remote folder(ls), unreadable through recursion: should fail
217 svntest
.actions
.run_and_verify_svn(None,
223 svntest
.actions
.run_and_verify_svn(None, None, [], 'cp',
227 # copy a remote file, source is unreadable: should fail
228 svntest
.actions
.run_and_verify_svn(None,
234 # copy a remote folder
235 svntest
.actions
.run_and_verify_svn(None, None, [], 'cp',
239 # copy a remote folder, source is unreadable: should fail
240 svntest
.actions
.run_and_verify_svn(None,
246 # test whether write access is correctly granted and denied
247 def authz_write_access(sbox
):
248 "test authz for write operations"
250 sbox
.build(create_wc
= False)
252 write_restrictive_svnserve_conf(sbox
.repo_dir
)
254 if sbox
.repo_url
.startswith('http'):
255 expected_err
= ".*403 Forbidden.*"
257 expected_err
= ".*svn: Access denied.*"
259 write_authz_file(sbox
, { "/": "* = r",
263 root_url
= sbox
.repo_url
264 A_url
= root_url
+ '/A'
268 mu_url
= A_url
+ '/mu'
269 iota_url
= root_url
+ '/iota'
270 lambda_url
= B_url
+ '/lambda'
273 # copy a remote file, target is readonly: should fail
274 svntest
.actions
.run_and_verify_svn(None,
280 # copy a remote folder, target is readonly: should fail
281 svntest
.actions
.run_and_verify_svn(None,
287 # delete a file, target is readonly: should fail
288 svntest
.actions
.run_and_verify_svn(None,
294 # delete a folder, target is readonly: should fail
295 svntest
.actions
.run_and_verify_svn(None,
301 # create a folder, target is readonly: should fail
302 svntest
.actions
.run_and_verify_svn(None,
308 # move a remote file, source is readonly: should fail
309 svntest
.actions
.run_and_verify_svn(None,
315 # move a remote folder, source is readonly: should fail
316 svntest
.actions
.run_and_verify_svn(None,
322 # move a remote file, target is readonly: should fail
323 svntest
.actions
.run_and_verify_svn(None,
329 # move a remote folder, target is readonly: should fail
330 svntest
.actions
.run_and_verify_svn(None,
336 #----------------------------------------------------------------------
338 def authz_checkout_test(sbox
):
339 "test authz for checkout"
341 sbox
.build(create_wc
= False, read_only
= True)
342 local_dir
= sbox
.wc_dir
344 write_restrictive_svnserve_conf(sbox
.repo_dir
)
346 # 1st part: disable all read access, checkout should fail
348 # write an authz file with *= on /
349 if sbox
.repo_url
.startswith('http'):
350 expected_err
= ".*403 Forbidden.*"
352 expected_err
= ".*svn: Authorization failed.*"
354 write_authz_file(sbox
, { "/": "* ="})
356 # checkout a working copy, should fail
357 svntest
.actions
.run_and_verify_svn(None, None, expected_err
,
358 'co', sbox
.repo_url
, local_dir
)
360 # 2nd part: now enable read access
362 write_authz_file(sbox
, { "/": "* = r"})
364 # checkout a working copy, should succeed because we have read access
365 expected_output
= svntest
.main
.greek_state
.copy()
366 expected_output
.wc_dir
= local_dir
367 expected_output
.tweak(status
='A ', contents
=None)
369 expected_wc
= svntest
.main
.greek_state
371 svntest
.actions
.run_and_verify_checkout(sbox
.repo_url
,
376 def authz_checkout_and_update_test(sbox
):
377 "test authz for checkout and update"
379 sbox
.build(create_wc
= False, read_only
= True)
380 local_dir
= sbox
.wc_dir
382 write_restrictive_svnserve_conf(sbox
.repo_dir
)
384 # 1st part: disable read access on folder A/B, checkout should not
385 # download this folder
387 # write an authz file with *= on /A/B
388 write_authz_file(sbox
, { "/": "* = r",
391 # checkout a working copy, should not dl /A/B
392 expected_output
= svntest
.main
.greek_state
.copy()
393 expected_output
.wc_dir
= local_dir
394 expected_output
.tweak(status
='A ', contents
=None)
395 expected_output
.remove('A/B', 'A/B/lambda', 'A/B/E', 'A/B/E/alpha',
396 'A/B/E/beta', 'A/B/F')
398 expected_wc
= svntest
.main
.greek_state
.copy()
399 expected_wc
.remove('A/B', 'A/B/lambda', 'A/B/E', 'A/B/E/alpha',
400 'A/B/E/beta', 'A/B/F')
402 svntest
.actions
.run_and_verify_checkout(sbox
.repo_url
, local_dir
,
406 # 2nd part: now enable read access
408 # write an authz file with *=r on /
409 write_authz_file(sbox
, { "/": "* = r"})
411 # update the working copy, should download /A/B because we now have read
413 expected_output
= svntest
.wc
.State(local_dir
, {
414 'A/B' : Item(status
='A '),
415 'A/B/lambda' : Item(status
='A '),
416 'A/B/E' : Item(status
='A '),
417 'A/B/E/alpha' : Item(status
='A '),
418 'A/B/E/beta' : Item(status
='A '),
419 'A/B/F' : Item(status
='A '),
422 expected_wc
= svntest
.main
.greek_state
423 expected_status
= svntest
.actions
.get_virginal_state(local_dir
, 1)
425 svntest
.actions
.run_and_verify_update(local_dir
,
433 def authz_partial_export_test(sbox
):
434 "test authz for export with unreadable subfolder"
436 sbox
.build(create_wc
= False, read_only
= True)
437 local_dir
= sbox
.wc_dir
439 # cleanup remains of a previous test run.
440 svntest
.main
.safe_rmtree(local_dir
)
442 write_restrictive_svnserve_conf(sbox
.repo_dir
)
444 # 1st part: disable read access on folder A/B, export should not
445 # download this folder
447 # write an authz file with *= on /A/B
448 write_authz_file(sbox
, { "/": "* = r", "/A/B": "* =" })
450 # export a working copy, should not dl /A/B
451 expected_output
= svntest
.main
.greek_state
.copy()
452 expected_output
.wc_dir
= local_dir
453 expected_output
.desc
[''] = Item()
454 expected_output
.tweak(status
='A ', contents
=None)
455 expected_output
.remove('A/B', 'A/B/lambda', 'A/B/E', 'A/B/E/alpha',
456 'A/B/E/beta', 'A/B/F')
458 expected_wc
= svntest
.main
.greek_state
.copy()
459 expected_wc
.remove('A/B', 'A/B/lambda', 'A/B/E', 'A/B/E/alpha',
460 'A/B/E/beta', 'A/B/F')
462 svntest
.actions
.run_and_verify_export(sbox
.repo_url
, local_dir
,
466 #----------------------------------------------------------------------
468 def authz_log_and_tracing_test(sbox
):
469 "test authz for log and tracing path changes"
474 write_restrictive_svnserve_conf(sbox
.repo_dir
)
476 # write an authz file with *=rw on /
477 if sbox
.repo_url
.startswith('http'):
478 expected_err
= ".*403 Forbidden.*"
480 expected_err
= ".*svn: Authorization failed.*"
482 write_authz_file(sbox
, { "/": "* = rw\n" })
484 root_url
= sbox
.repo_url
485 D_url
= root_url
+ '/A/D'
488 # check if log doesn't spill any info on which you don't have read access
489 rho_path
= os
.path
.join(wc_dir
, 'A', 'D', 'G', 'rho')
490 svntest
.main
.file_append(rho_path
, 'new appended text for rho')
492 svntest
.actions
.run_and_verify_svn(None, None, [],
493 'ci', '-m', 'add file rho', sbox
.wc_dir
)
495 svntest
.main
.file_append(rho_path
, 'extra change in rho')
497 svntest
.actions
.run_and_verify_svn(None, None, [],
498 'ci', '-m', 'changed file rho',
502 svntest
.actions
.run_and_verify_svn(None, None, [], 'cp',
504 '-m', 'copy rho to readable area')
506 # now disable read access on the first version of rho, keep the copy in
508 if sbox
.repo_url
.startswith('http'):
509 expected_err
= ".*403 Forbidden.*"
511 expected_err
= ".*svn: Authorization failed.*"
513 authz
= { "/": "* = rw",
515 write_authz_file(sbox
, authz
)
519 # changed file in this rev. is not readable anymore, so author and date
520 # should be hidden, like this:
521 # r2 | (no author) | (no date) | 1 line
522 svntest
.actions
.run_and_verify_svn(None,
523 ".*(no author).*(no date).*|-+\n|\n", [],
524 'log', '-r', '2', '--limit', '1',
527 if sbox
.repo_url
.startswith('http'):
528 expected_err2
= expected_err
530 expected_err2
= ".*svn: Item is not readable.*"
532 # if we do the same thing directly on the unreadable file, we get:
533 # svn: Item is not readable
534 svntest
.actions
.run_and_verify_svn(None, None, expected_err2
,
537 # while the HEAD rev of the copy is readable in /A/D, its parent in
538 # /A/D/G is not, so don't spill any info there either.
539 svntest
.actions
.run_and_verify_svn(None,
540 ".*(no author).*(no date).*|-+\n|\n", [],
541 'log', '-r', '2', '--limit', '1', D_url
)
543 # Test that only author/date are shown for partially visible revisions.
544 svntest
.actions
.enable_revprop_changes(sbox
.repo_dir
)
545 write_authz_file(sbox
, { "/": "* = rw"})
546 svntest
.actions
.run_and_verify_svn(
547 None, None, [], # message, expected_stdout, expected_stderr
548 'ps', '--revprop', '-r1', 'foobar', 'foo bar', sbox
.repo_url
)
549 svntest
.actions
.run_and_verify_log_xml(
550 expected_revprops
=[{'svn:author': svntest
.main
.wc_author
, 'svn:date': '',
551 'svn:log': 'Log message for revision 1.',
552 'foobar': 'foo bar'}],
553 args
=['--with-all-revprops', '-r1', sbox
.repo_url
])
554 write_authz_file(sbox
, authz
)
555 svntest
.actions
.run_and_verify_log_xml(
556 expected_revprops
=[{'svn:author': svntest
.main
.wc_author
, 'svn:date': ''}],
557 args
=['--with-all-revprops', '-r1', sbox
.repo_url
])
562 # now see if we can look at the older version of rho
563 svntest
.actions
.run_and_verify_svn(None, None, expected_err
,
564 'cat', '-r', '2', D_url
+'/rho')
566 if sbox
.repo_url
.startswith('http'):
567 expected_err2
= expected_err
569 expected_err2
= ".*svn: Unreadable path encountered; access denied.*"
571 svntest
.actions
.run_and_verify_svn(None, None, expected_err2
,
572 'cat', '-r', '2', G_url
+'/rho')
576 # we shouldn't see the diff of a file in an unreadable path
577 svntest
.actions
.run_and_verify_svn(None, None, expected_err
,
578 'diff', '-r', 'HEAD', G_url
+'/rho')
580 svntest
.actions
.run_and_verify_svn(None, None, expected_err
,
581 'diff', '-r', '2', D_url
+'/rho')
583 svntest
.actions
.run_and_verify_svn(None, None, expected_err
,
584 'diff', '-r', '2:4', D_url
+'/rho')
586 # test whether read access is correctly granted and denied
587 def authz_aliases(sbox
):
588 "test authz for aliases"
590 sbox
.build(create_wc
= False)
592 write_restrictive_svnserve_conf(sbox
.repo_dir
)
594 if sbox
.repo_url
.startswith("http"):
595 expected_err
= ".*403 Forbidden.*"
597 expected_err
= ".*svn: Authorization failed.*"
599 write_authz_file(sbox
, { "/" : "* = r",
600 "/A/B" : "&jray = rw" },
601 { "aliases" : 'jray = jrandom' } )
603 root_url
= sbox
.repo_url
604 A_url
= root_url
+ '/A'
606 iota_url
= root_url
+ '/iota'
608 # copy a remote file, target is readonly for jconstant: should fail
609 svntest
.actions
.run_and_verify_svn(None,
612 '--username', svntest
.main
.wc_author2
,
616 # try the same action, but as user jray (alias of jrandom), should work.
617 svntest
.actions
.run_and_verify_svn(None,
623 def authz_validate(sbox
):
624 "test the authz validation rules"
626 sbox
.build(create_wc
= False, read_only
= True)
628 write_restrictive_svnserve_conf(sbox
.repo_dir
)
630 A_url
= sbox
.repo_url
+ '/A'
632 # If any of the validate rules fail, the authz isn't loaded so there's no
633 # access at all to the repository.
635 # Test 1: Undefined group
636 write_authz_file(sbox
, { "/" : "* = r",
637 "/A/B" : "@undefined_group = rw" })
639 if sbox
.repo_url
.startswith("http"):
640 expected_err
= ".*403 Forbidden.*"
641 elif sbox
.repo_url
.startswith("svn"):
642 expected_err
= ".*Invalid authz configuration"
644 expected_err
= ".*@undefined_group.*"
646 # validation of this authz file should fail, so no repo access
647 svntest
.actions
.run_and_verify_svn("ls remote folder",
652 # Test 2: Circular dependency
653 write_authz_file(sbox
, { "/" : "* = r" },
654 { "groups" : """admins = admin1, admin2, @devs
655 devs1 = @admins, dev1
656 devs2 = @admins, dev2
657 devs = @devs1, dev3, dev4""" })
659 if sbox
.repo_url
.startswith("http"):
660 expected_err
= ".*403 Forbidden.*"
661 elif sbox
.repo_url
.startswith("svn"):
662 expected_err
= ".*Invalid authz configuration"
664 expected_err
= ".*Circular dependency.*"
666 # validation of this authz file should fail, so no repo access
667 svntest
.actions
.run_and_verify_svn("ls remote folder",
672 # Test 3: Group including other group 2 times (issue 2684)
673 write_authz_file(sbox
, { "/" : "* = r" },
674 { "groups" : """admins = admin1, admin2
675 devs1 = @admins, dev1
676 devs2 = @admins, dev2
677 users = @devs1, @devs2, user1, user2""" })
679 # validation of this authz file should fail, so no repo access
680 svntest
.actions
.run_and_verify_svn("ls remote folder",
681 ['B/\n', 'C/\n', 'D/\n', 'mu\n'],
686 # test locking/unlocking with authz
687 def authz_locking(sbox
):
688 "test authz for locking"
692 write_authz_file(sbox
, {"/": "", "/A": "jrandom = rw"})
693 write_restrictive_svnserve_conf(sbox
.repo_dir
)
695 if sbox
.repo_url
.startswith('http'):
696 expected_err
= ".*403 Forbidden.*"
698 expected_err
= ".*svn: Authorization failed.*"
700 root_url
= sbox
.repo_url
702 iota_url
= root_url
+ '/iota'
703 iota_path
= os
.path
.join(wc_dir
, 'iota')
704 A_url
= root_url
+ '/A'
705 mu_path
= os
.path
.join(wc_dir
, 'A', 'mu')
707 # lock a file url, target is readonly: should fail
708 svntest
.actions
.run_and_verify_svn(None,
714 # lock a file path, target is readonly: should fail
715 svntest
.actions
.run_and_verify_svn(None,
721 # Test for issue 2700: we have write access in folder /A, but not in root.
722 # Get a lock on /A/mu and try to commit it.
724 # lock a file path, target is writeable: should succeed
725 svntest
.actions
.run_and_verify_svn(None,
731 svntest
.main
.file_append(mu_path
, "hi")
733 expected_output
= svntest
.wc
.State(wc_dir
, {
734 'A/mu' : Item(verb
='Sending'),
737 svntest
.actions
.run_and_verify_commit(wc_dir
,
743 # test for issue #2712: if anon-access == read, svnserve should also check
744 # authz to determine whether a checkout/update is actually allowed for
745 # anonymous users, and, if not, attempt authentication.
746 def authz_svnserve_anon_access_read(sbox
):
749 sbox
.build(create_wc
= False)
750 svntest
.main
.safe_rmtree(sbox
.wc_dir
)
751 B_path
= os
.path
.join(sbox
.wc_dir
, 'A', 'B')
752 other_B_path
= B_path
+ '_other'
753 B_url
= sbox
.repo_url
+ '/A/B'
754 D_path
= os
.path
.join(sbox
.wc_dir
, 'A', 'D')
755 D_url
= sbox
.repo_url
+ '/A/D'
757 # We want a svnserve.conf with anon-access = read.
758 write_restrictive_svnserve_conf(sbox
.repo_dir
, "read")
760 # Give jrandom read access to /A/B. Anonymous users can only
762 write_authz_file(sbox
, { "/A/B" : "jrandom = rw",
765 # Perform a checkout of /A/B, expecting to see no errors.
766 svntest
.actions
.run_and_verify_svn(None, None, [],
770 # Anonymous users should be able to check out /A/D.
771 svntest
.actions
.run_and_verify_svn(None, None, [],
776 svntest
.main
.safe_rmtree(D_path
)
777 svntest
.actions
.run_and_verify_svn(None, None, [],
778 'switch', D_url
, B_path
)
780 # Check out /A/B with an unknown username, expect error.
781 svntest
.actions
.run_and_verify_svn(
783 ".*Authentication error from server: Username not found.*",
786 '--username', 'losing_user',
787 B_url
, B_path
+ '_unsuccessful')
789 # Check out a second copy of /A/B, make changes for later merge.
790 svntest
.actions
.run_and_verify_svn(None, None, [],
793 other_alpha_path
= os
.path
.join(other_B_path
, 'E', 'alpha')
794 svntest
.main
.file_append(other_alpha_path
, "fish\n")
795 svntest
.actions
.run_and_verify_svn(None, None, [],
796 'commit', '-m', 'log msg',
799 # Now try to merge. This is an atypical merge, since our "branch"
800 # is not really a branch (it's the same URL), but we only care about
801 # authz here, not the semantics of the merge. (Merges had been
802 # failing in authz, for the reasons summarized in
803 # http://subversion.tigris.org/issues/show_bug.cgi?id=2712#desc13.)
804 svntest
.actions
.run_and_verify_svn(None, None, [],
808 def authz_switch_to_directory(sbox
):
809 "switched to directory, no read access on parents"
811 sbox
.build(read_only
= True)
813 write_authz_file(sbox
, {"/": "*=rw", "/A/B": "*=", "/A/B/E": "jrandom = rw"})
815 write_restrictive_svnserve_conf(sbox
.repo_dir
)
818 mu_path
= os
.path
.join(wc_dir
, 'A', 'mu')
819 F_path
= os
.path
.join(wc_dir
, 'A', 'B', 'F')
820 G_path
= os
.path
.join(wc_dir
, 'A', 'D', 'G')
822 # Switch /A/B/E to /A/B/F.
823 svntest
.main
.run_svn(None, 'switch', sbox
.repo_url
+ "/A/B/E", G_path
)
825 ########################################################################
828 # list all tests here, starting with None:
830 Skip(authz_open_root
, svntest
.main
.is_ra_type_file
),
831 Skip(authz_open_directory
, svntest
.main
.is_ra_type_file
),
832 Skip(broken_authz_file
, svntest
.main
.is_ra_type_file
),
833 Skip(authz_read_access
, svntest
.main
.is_ra_type_file
),
834 Skip(authz_write_access
, svntest
.main
.is_ra_type_file
),
835 Skip(authz_checkout_test
, svntest
.main
.is_ra_type_file
),
836 Skip(authz_log_and_tracing_test
, svntest
.main
.is_ra_type_file
),
837 Skip(authz_checkout_and_update_test
,
838 svntest
.main
.is_ra_type_file
),
839 Skip(authz_partial_export_test
, svntest
.main
.is_ra_type_file
),
840 SkipUnless(Skip(authz_aliases
, svntest
.main
.is_ra_type_file
),
841 server_authz_has_aliases
),
842 Skip(authz_validate
, svntest
.main
.is_ra_type_file
),
843 Skip(authz_locking
, svntest
.main
.is_ra_type_file
),
844 XFail(SkipUnless(authz_svnserve_anon_access_read
,
845 svntest
.main
.is_ra_type_svn
)),
846 XFail(Skip(authz_switch_to_directory
,
847 svntest
.main
.is_ra_type_file
)),
850 if __name__
== '__main__':
851 svntest
.main
.run_tests(test_list
, serial_only
= True)