[svn.haxx.se] · SVN Dev · SVN Users · SVN Org · TSVN Dev · TSVN Users · Subclipse Dev · Subclipse Users · this month's index

Re: svn commit: r34896 - trunk/subversion/tests/libsvn_fs_base

From: C. Michael Pilato <cmpilato_at_collab.net>
Date: Tue, 23 Dec 2008 13:40:28 -0500

FSFS fails with a different error altogether, preventing the commit, and
forcing the entire test logic down a whole 'nuther path. Rather than have a
giant conditional in the test logic, I just wrote the test for fs-base.

David Glasser wrote:
> This test seems to only exercise the FS API, so it ought to pass
> against FSFS too. Why not put it in fs-test? Just because FSFS
> didn't have this bug now (or did it?) doesn't mean it's not a worthy
> test.
>
> --dave
>
> On Tue, Dec 23, 2008 at 7:35 AM, C. Michael Pilato <cmpilato_at_collab.net> wrote:
>> Author: cmpilato
>> Date: Tue Dec 23 07:35:08 2008
>> New Revision: 34896
>>
>> Log:
>> Add regression text for issue #3349 (BDB backend could allow `changes'
>> table out-of-sync with actual changes).
>>
>> * subversion/tests/libsvn_fs_base/fs-base-test.c
>> (orphaned_textmod_change): New regression test.
>> (test_funcs): Add reference to new test.
>>
>> Modified:
>> trunk/subversion/tests/libsvn_fs_base/fs-base-test.c
>>
>> Modified: trunk/subversion/tests/libsvn_fs_base/fs-base-test.c
>> URL: http://svn.collab.net/viewvc/svn/trunk/subversion/tests/libsvn_fs_base/fs-base-test.c?pathrev=34896&r1=34895&r2=34896
>> ==============================================================================
>> --- trunk/subversion/tests/libsvn_fs_base/fs-base-test.c Tue Dec 23 05:34:01 2008 (r34895)
>> +++ trunk/subversion/tests/libsvn_fs_base/fs-base-test.c Tue Dec 23 07:35:08 2008 (r34896)
>> @@ -1463,6 +1463,65 @@ redundant_copy(const char **msg,
>> }
>>
>>
>> +static svn_error_t *
>> +orphaned_textmod_change(const char **msg,
>> + svn_boolean_t msg_only,
>> + svn_test_opts_t *opts,
>> + apr_pool_t *pool)
>> +{
>> + apr_pool_t *subpool = svn_pool_create(pool);
>> + svn_fs_t *fs;
>> + svn_fs_txn_t *txn;
>> + svn_fs_root_t *txn_root, *root;
>> + svn_revnum_t youngest_rev = 0;
>> + svn_txdelta_window_handler_t wh_func;
>> + void *wh_baton;
>> + apr_hash_t *changed_paths;
>> +
>> + *msg = "test for orphaned textmod changed paths";
>> + if (msg_only)
>> + return SVN_NO_ERROR;
>> +
>> + /* Create a filesystem and repository. */
>> + SVN_ERR(svn_test__create_bdb_fs(&fs, "test-repo-orphaned-changes", opts,
>> + pool));
>> +
>> + /* Revision 1: Create and commit the greek tree. */
>> + SVN_ERR(svn_fs_begin_txn(&txn, fs, 0, subpool));
>> + SVN_ERR(svn_fs_txn_root(&txn_root, txn, subpool));
>> + SVN_ERR(svn_test__create_greek_tree(txn_root, subpool));
>> + SVN_ERR(svn_fs_commit_txn(NULL, &youngest_rev, txn, subpool));
>> + svn_pool_clear(subpool);
>> +
>> + /* Revision 2: Start to change "iota", but don't complete the work. */
>> + SVN_ERR(svn_fs_begin_txn(&txn, fs, youngest_rev, subpool));
>> + SVN_ERR(svn_fs_txn_root(&txn_root, txn, subpool));
>> + SVN_ERR(svn_fs_apply_textdelta
>> + (&wh_func, &wh_baton, txn_root, "iota", NULL, NULL, subpool));
>> + /* Don't send any delta windows! */
>> + SVN_ERR(svn_fs_commit_txn(NULL, &youngest_rev, txn, subpool));
>> + svn_pool_clear(subpool);
>> +
>> + /* Fetch changed paths for the youngest revision. We should find none. */
>> + SVN_ERR(svn_fs_revision_root(&root, fs, youngest_rev, subpool));
>> + SVN_ERR(svn_fs_paths_changed(&changed_paths, root, subpool));
>> + if (apr_hash_count(changed_paths) != 0)
>> + {
>> + svn_fs_path_change_t *change = apr_hash_get(changed_paths, "/iota",
>> + APR_HASH_KEY_STRING);
>> + if (change && change->text_mod)
>> + return svn_error_create(SVN_ERR_TEST_FAILED, NULL,
>> + "Got unexpected textmods changed path "
>> + "for 'iota'");
>> + else
>> + return svn_error_create(SVN_ERR_TEST_FAILED, NULL,
>> + "Got non-empty changed paths hash where empty "
>> + "one expected");
>> + }
>> +
>> + return SVN_NO_ERROR;
>> +}
>> +
>> /* ------------------------------------------------------------------------ */
>>
>> /* The test table. */
>> @@ -1479,5 +1538,6 @@ struct svn_test_descriptor_t test_funcs[
>> SVN_TEST_PASS(canonicalize_abspath),
>> SVN_TEST_PASS(skip_deltas),
>> SVN_TEST_PASS(redundant_copy),
>> + SVN_TEST_XFAIL(orphaned_textmod_change),
>> SVN_TEST_NULL
>> };
>>
>> ------------------------------------------------------
>> http://subversion.tigris.org/ds/viewMessage.do?dsForumId=495&dsMessageId=990751
>>
>
>
>

-- 
C. Michael Pilato <cmpilato_at_collab.net>
CollabNet   <>   www.collab.net   <>   Distributed Development On Demand
------------------------------------------------------
http://subversion.tigris.org/ds/viewMessage.do?dsForumId=462&dsMessageId=990854

Received on 2008-12-23 19:40:50 CET

This is an archived mail posted to the Subversion Dev mailing list.

This site is subject to the Apache Privacy Policy and the Apache Public Forum Archive Policy.