From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Simon.Cathebras" Subject: Re: [PATCH 5/6] Tests of UTF8 character with git-remote-mediawiki Date: Tue, 12 Jun 2012 23:18:58 +0200 Message-ID: <4FD7B242.9020005@ensimag.imag.fr> References: <20120611230954.Horde.inb-aHwdC4BP1l6iLlHhZgA@webmail.minatec.grenoble-inp.fr> <1339535563-18958-1-git-send-email-simon.cathebras@ensimag.imag.fr> <1339535563-18958-5-git-send-email-simon.cathebras@ensimag.imag.fr> Reply-To: Simon.Cathebras@ensimag.imag.fr Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: QUOTED-PRINTABLE Cc: git@vger.kernel.org, gitster@pobox.com, peff@peff.net, Simon Perrat , Guillaume Sasdy , Charles Roussel , Julien Khayat , Matthieu Moy To: Simon Cathebras X-From: git-owner@vger.kernel.org Tue Jun 12 23:19:18 2012 Return-path: Envelope-to: gcvg-git-2@plane.gmane.org Received: from vger.kernel.org ([209.132.180.67]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1SeYUe-0007WA-RY for gcvg-git-2@plane.gmane.org; Tue, 12 Jun 2012 23:19:17 +0200 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754196Ab2FLVTL convert rfc822-to-quoted-printable (ORCPT ); Tue, 12 Jun 2012 17:19:11 -0400 Received: from mx2.imag.fr ([129.88.30.17]:44582 "EHLO rominette.imag.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752153Ab2FLVTK (ORCPT ); Tue, 12 Jun 2012 17:19:10 -0400 Received: from ensimag.imag.fr (ensimag.imag.fr [195.221.228.12]) by rominette.imag.fr (8.13.8/8.13.8) with ESMTP id q5CL9nwH002349 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Tue, 12 Jun 2012 23:09:49 +0200 Received: from [IPv6:::1] (ensibm [195.221.228.8]) by ensimag.imag.fr (8.13.8/8.13.8/ImagV2.1.r_ens) with ESMTP id q5CLIv0p032135; Tue, 12 Jun 2012 23:18:57 +0200 User-Agent: Mozilla/5.0 (X11; Linux i686; rv:12.0) Gecko/20120430 Thunderbird/12.0.1 In-Reply-To: <1339535563-18958-5-git-send-email-simon.cathebras@ensimag.imag.fr> X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.2.2 (rominette.imag.fr [129.88.30.17]); Tue, 12 Jun 2012 23:09:49 +0200 (CEST) X-IMAG-MailScanner-Information: Please contact MI2S MIM for more information X-MailScanner-ID: q5CL9nwH002349 X-IMAG-MailScanner: Found to be clean X-IMAG-MailScanner-SpamCheck: X-IMAG-MailScanner-From: simon.cathebras@ensimag.imag.fr MailScanner-NULL-Check: 1340140190.95588@JgYSJic9wr8XAklFLzxe4A Sender: git-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: git@vger.kernel.org Archived-At: Please accept our appologize for the bad tag for patches. The PATCH 5 is actually the last one... Regards. Simon C On 12/06/2012 23:12, Simon Cathebras wrote: > This patch provides a sample of tests for git-remote-mediawiki's > resistance, concerning utf8 special characters. > > Signed-off-by: Simon Cathebras > Signed-off-by: Simon Perrat > Signed-off-by: Guillaume Sasdy > Signed-off-by: Charles Roussel > Signed-off-by: Julien Khayat > Signed-off-by: Matthieu Moy > --- > contrib/mw-to-git/t/t9362-mw-to-git-utf8.sh | 271 +++++++++++++++++= +++++++++++ > 1 file changed, 271 insertions(+) > create mode 100755 contrib/mw-to-git/t/t9362-mw-to-git-utf8.sh > > diff --git a/contrib/mw-to-git/t/t9362-mw-to-git-utf8.sh b/contrib/mw= -to-git/t/t9362-mw-to-git-utf8.sh > new file mode 100755 > index 0000000..9227c6f > --- /dev/null > +++ b/contrib/mw-to-git/t/t9362-mw-to-git-utf8.sh > @@ -0,0 +1,271 @@ > +#!/bin/sh > +# > +# Copyright (C) 2012 > +# Charles Roussel > +# Simon Cathebras > +# Julien Khayat > +# Guillaume Sasdy > +# Simon Perrat > +# > +# License: GPL v2 or later > + > +# tests for git-remote-mediawiki > + > +test_description=3D'Test git-mediawiki with special characters in fi= lenames' > + > +. ./test-gitmw-lib.sh > +. $TEST_DIRECTORY/test-lib.sh > + > + > +test_check_precond > + > + > +test_expect_success 'Git clone works for a wiki with accents in the = page names' ' > + wiki_reset&& > + wiki_editpage f=C3=A9=C3=A9 "This page must be d=C3=A9l=C3=A9t=C3=A9= d before clone" false&& > + wiki_editpage k=C3=A8=C3=A8 "This page must be deleted before clone= " false&& > + wiki_editpage h=C3=A0=C3=A0 "This page must be deleted before clone= " false&& > + wiki_editpage k=C3=AE=C3=AE "This page must be deleted before clone= " false&& > + wiki_editpage foo "This page must be deleted before clone" false&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_1&& > + wiki_getallpage ref_page_1&& > + test_diff_directories mw_dir_1 ref_page_1 > +' > + > + > +test_expect_success 'Git pull works with a wiki with accents in the = pages names' ' > + wiki_reset&& > + wiki_editpage k=C3=AE=C3=AE "this page must be cloned" false&& > + wiki_editpage foo "this page must be cloned" false&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_2&& > + wiki_editpage =C3=A9=C3=A0=C3=AE=C3=B4=C3=BB "This page must be pul= led" false&& > + (cd mw_dir_2&& > + git pull )&& > + wiki_getallpage ref_page_2&& > + test_diff_directories mw_dir_2 ref_page_2 > +' > + > +# 3 > +test_expect_success 'Cloning a chosen page works with accents' ' > + wiki_reset&& > + wiki_editpage k=C3=AE=C3=AE "this page must be cloned" false&& > + git clone -c remote.origin.pages=3Dk=C3=AE=C3=AE mediawiki::http://= '"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' mw_dir_3&& > + wiki_check_content mw_dir_3/K=C3=AE=C3=AE.mw K=C3=AE=C3=AE&& > + test -e mw_dir_3/K=C3=AE=C3=AE.mw&& > + rm -rf mw_dir_3 > +' > + > + > +test_expect_success 'The shallow option works with accents' ' > + wiki_reset&& > + wiki_editpage n=C3=A9o=C3=A0 "1st revision, should not be cloned" f= alse&& > + wiki_editpage n=C3=A9o=C3=A0 "2nd revision, should be cloned" false= && > + git -c remote.origin.shallow=3Dtrue clone mediawiki::http://'"$SERV= ER_ADDR:$PORT/$WIKI_DIR_NAME"' mw_dir_4&& > + test_contains_N_files mw_dir_4 2&& > + test -e mw_dir_4/N=C3=A9o=C3=A0.mw&& > + test -e mw_dir_4/Main_Page.mw&& > + (cd mw_dir_4&& > + test `git log --oneline N=C3=A9o=C3=A0.mw | wc -l` -eq 1&& > + test `git log --oneline Main_Page.mw | wc -l ` -eq 1 )&& > + wiki_check_content mw_dir_4/N=C3=A9o=C3=A0.mw N=C3=A9o=C3=A0&& > + wiki_check_content mw_dir_4/Main_Page.mw Main_Page > +' > + > + > +test_expect_success 'Cloning works when page name first letter has a= n accent' ' > + wiki_reset&& > + wiki_editpage =C3=AE=C3=AE "this page must be cloned" false&& > + git clone -c remote.origin.pages=3D=C3=AE=C3=AE mediawiki::http://'= "$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' mw_dir_5&& > + test -e mw_dir_5/=C3=8E=C3=AE.mw&& > + wiki_check_content mw_dir_5/=C3=8E=C3=AE.mw =C3=8E=C3=AE > +' > + > + > +test_expect_success 'Git push works with a wiki with accents' ' > + wiki_reset&& > + wiki_editpage f=C3=A9=C3=A9 "lots of accents : =C3=A9=C3=A8=C3=A0=C3= =96" false&& > + wiki_editpage foo "this page must be cloned" false&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_6&& > + (cd mw_dir_6&& > + echo "A wild P=C3=AEk=C3=A4ch=C3=BB appears on the wiki"> P=C3=AEk= =C3=A4ch=C3=BB.mw&& > + git add P=C3=AEk=C3=A4ch=C3=BB.mw&& > + git commit -m "A new page appears"&& > + git push )&& > + wiki_getallpage ref_page_6&& > + test_diff_directories mw_dir_6 ref_page_6 > +' > + > +test_expect_success 'Git clone works with accentsand spaces' ' > + wiki_reset&& > + wiki_editpage "=C3=A9 =C3=A0 =C3=AE" "this page must be d=C3=A9l=C3= =A9t=C3=A9 before the clone" false&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_7&& > + wiki_getallpage ref_page_7&& > + test_diff_directories mw_dir_7 ref_page_7 > +' > + > +test_expect_success 'character $ in page name (mw -> git)' ' > + wiki_reset&& > + wiki_editpage file_\$_foo "expect to be called file_$_foo" false&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_8&& > + test -f mw_dir_8/File_\$_foo.mw&& > + wiki_getallpage ref_page_8&& > + test_diff_directories mw_dir_8 ref_page_8 > +' > + > + > + > +test_expect_success 'character $ in file name (git -> mw) ' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_9&& > + (cd mw_dir_9&& > + echo "this file is called File_\$_foo.mw"> File_\$_foo.mw&& > + git add .&& > + git commit -am "file File_\$_foo.mw"&& > + git pull&& > + git push )&& > + wiki_getallpage ref_page_9&& > + test_diff_directories mw_dir_9 ref_page_9 > +' > + > + > +test_expect_failure 'capital at the begining of file names' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_10&& > + (cd mw_dir_10&& > + echo "my new file foo"> foo.mw&& > + echo "my new file Foo... Finger crossed"> Foo.mw&& > + git add .&& > + git commit -am "file foo.mw"&& > + git pull&& > + git push )&& > + wiki_getallpage ref_page_10&& > + test_diff_directories mw_dir_10 ref_page_10 > +' > + > + > +test_expect_failure 'special character at the begining of file name = from mw to git' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_11&& > + wiki_editpage {char_1 "expect to be renamed {char_1" false&& > + wiki_editpage [char_2 "expect to be renamed [char_2" false&& > + (cd mw_dir_11&& > + git pull )&& > + test -f mw_dir_11/{char_1&& > + test -f mw_dir_11/[char_2 > +' > + > + > +test_expect_success 'test of correct formating for file name from mw= to git' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_12&& > + wiki_editpage char{_1 "expect to be renamed char{_1" false&& > + wiki_editpage char[_2 "expect to be renamed char{_2" false&& > + (cd mw_dir_12&& > + git pull )&& > + test -f mw_dir_12/Char\{_1.mw&& > + test -f mw_dir_12/Char\[_2.mw&& > + wiki_getallpage ref_page_12&& > + test_diff_directories mw_dir_12 ref_page_12 > +' > + > + > +test_expect_failure 'test of correct formating for file name beginin= g with special character' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_13&& > + (cd mw_dir_13&& > + echo "my new file {char_1"> \{char_1.mw&& > + echo "my new file [char_2"> \[char_2.mw&& > + git add .&& > + git commit -am "commiting some exotic file name..."&& > + git push&& > + git pull)&& > + wiki_getallpage ref_page_13&& > + test -f ref_page_13/{char_1.mw&& > + test -f ref_page_13/[char_2.mw&& > + test_diff_directories mw_dir_13 ref_page_13 > +' > + > + > +test_expect_success 'test of correct formating for file name from gi= t to mw' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_14&& > + (cd mw_dir_14&& > + echo "my new file char{_1"> Char\{_1.mw&& > + echo "my new file char[_2"> Char\[_2.mw&& > + git add .&& > + git commit -m "commiting some exotic file name..."&& > + git push )&& > + wiki_getallpage ref_page_14&& > + test_diff_directories mw_dir_14 ref_page_14 > +' > + > + > +test_expect_success 'git clone with /' ' > + wiki_reset&& > + wiki_editpage \/fo\/o "this is not important" false -c=3DDeleted&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_15&& > + test -f mw_dir_15/%2Ffo%2Fo.mw&& > + wiki_check_content mw_dir_15/%2Ffo%2Fo.mw \/fo\/o > +' > + > + > +test_expect_success 'git push with /' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_16&& > + echo "I will be on the wiki"> mw_dir_16/%2Ffo%2Fo.mw&& > + (cd mw_dir_16&& > + git add %2Ffo%2Fo.mw&& > + git commit -m " %2Ffo%2Fo added"&& > + git push)&& > + wiki_page_exist \/fo\/o&& > + wiki_check_content mw_dir_16/%2Ffo%2Fo.mw \/fo\/o > + > +' > + > + > +test_expect_success 'git clone with \' ' > + wiki_reset&& > + wiki_editpage \\ko\\o "this is not important" false -c=3DDeleted&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_17&& > + test -f mw_dir_17/\\ko\\o.mw&& > + wiki_check_content mw_dir_17/\\ko\\o.mw \\ko\\o > +' > + > + > +test_expect_success 'git push with \' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_18&& > + echo "I will be on the wiki"> mw_dir_18/\\ko\\o.mw&& > + (cd mw_dir_18&& > + git add \\ko\\o.mw&& > + git commit -m " \\ko\\o added"&& > + git push )&& > + wiki_page_exist \\ko\\o&& > + wiki_check_content mw_dir_18/\\ko\\o.mw \\ko\\o > + > +' > + > +test_expect_success 'git clone with \ in format control' ' > + wiki_reset&& > + wiki_editpage \\no\\o "this is not important" false&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_19&& > + test -f mw_dir_19/\\no\\o.mw&& > + wiki_check_content mw_dir_19/\\no\\o.mw \\no\\o > +' > + > + > +test_expect_success 'git push with \ in format control' ' > + wiki_reset&& > + git clone mediawiki::http://'"$SERVER_ADDR:$PORT/$WIKI_DIR_NAME"' m= w_dir_20&& > + echo "I will be on the wiki"> mw_dir_20/\\fo\\o.mw&& > + (cd mw_dir_20&& > + git add \\fo\\o.mw&& > + git commit -m " \\fo\\o added"&& > + git push )&& > + wiki_page_exist \\fo\\o&& > + wiki_check_content mw_dir_20/\\fo\\o.mw \\fo\\o > + > +' > + > + > +test_done --=20 CATHEBRAS Simon 2A-ENSIMAG =46ili=C3=A8re Ing=C3=A9ni=C3=A9rie des Syst=C3=A8mes d'Information Membre Bug-Buster