Ejemplo n.º 1
0
    def export(self, authors_file, repos):
        header('Exporting %s repository.' % self.name)

        svn_mirror = path(self.config.svn_mirror, self.name)
        svn_export = path(self.config.svn_export, self.name)

        if not os.path.isdir(svn_export):
            call('mkdir -p %s' % svn_export)

        repos_to_process = []
        for repo in self.config.get_repos(self.name):
            if os.path.isfile(repo.rules) and \
               (repos is None or repo.name in repos.split(';')):
                repos_to_process.append(repo)

        # remove all previously exported repositories
        for repo in repos_to_process:
            repo_path = path(svn_export, repo.name)
            if os.path.isdir(repo_path):
                # just to be 100% we are removing something from svn_export folder
                if repo_path.startswith(svn_export):
                    call('rm -rf %s' % repo_path)

        call('%s --identity-map %s --rules %s --add-metadata %s' %
             (self.config.svn_all_fast_export, authors_file, ','.join(
                 [repo.rules for repo in repos_to_process]), svn_mirror),
             cwd=svn_export)
Ejemplo n.º 2
0
        def compare_content(msg, svn, git):
            line('%s "%s"(svn) vs. "%s"(git)' % (msg, svn[1], git[1]), 1)

            svn_path = path(self.config.analyze_path, self.name, 'svn', svn[1])
            git_path = path(self.config.analyze_path, self.name, 'git', git[1])

            if not os.path.isdir(svn_path):
                call('mkdir -p %s' % path(svn_path, '..'))
                call('svn export -q file://%s %s' % (svn[0], svn_path))
            if not os.path.isdir(git_path):
                call('mkdir -p %s' % path(git_path, '..'))
                call('git clone -q %s %s' % (git[0], git[1]),
                     cwd=path(git_path, '..'))
                call('git checkout -q %s' % git[1], cwd=git_path)

            diff = call(
                'diff -q -r -I "\$Id.*\$" -I "\$Date.*\$" --exclude ".git" %s %s'
                % (svn_path, git_path),
                stdout=PIPE,
                stderr=PIPE)
            if diff:
                for i in diff.split('\n'):
                    line(i, 2)
            else:
                line("everything ok", 2)
Ejemplo n.º 3
0
    def export(self, authors_file, repos):
        header('Exporting %s repository.' % self.name)

        svn_mirror = path(self.config.svn_mirror, self.name)
        svn_export = path(self.config.svn_export, self.name)

        if not os.path.isdir(svn_export):
            call('mkdir -p %s' % svn_export)

        repos_to_process = []
        for repo in self.config.get_repos(self.name):
            if os.path.isfile(repo.rules) and \
               (repos is None or repo.name in repos.split(';')):
                repos_to_process.append(repo)

        # remove all previously exported repositories
        for repo in repos_to_process:
            repo_path = path(svn_export, repo.name)
            if os.path.isdir(repo_path):
                # just to be 100% we are removing something from svn_export folder
                if repo_path.startswith(svn_export):
                    call('rm -rf %s' % repo_path)

        call('%s --identity-map %s --rules %s --add-metadata %s' % (
                self.config.svn_all_fast_export, authors_file,
                ','.join([ repo.rules for repo in repos_to_process ]),
                svn_mirror), cwd=svn_export)
Ejemplo n.º 4
0
 def initialize(self):
     svn_mirror = path(self.config.svn_mirror, self.name)
     if not os.path.isdir(svn_mirror):
         header('Initializing %s repository.' % self.name)
         call("svnadmin create %s" % svn_mirror)
         hook_path = path(svn_mirror, 'hooks', 'pre-revprop-change')
         with open(hook_path, 'w') as fd:
             fd.writelines(['#!/bin/sh\n', 'exit 0'])
         call('chmod 755 ' + hook_path)
         call('svnsync init file://%s %s' % (svn_mirror, self.remote_url))
Ejemplo n.º 5
0
 def initialize(self):
     svn_mirror = path(self.config.svn_mirror, self.name)
     if not os.path.isdir(svn_mirror):
         header('Initializing %s repository.' % self.name)
         call("svnadmin create %s" % svn_mirror)
         hook_path = path(svn_mirror, 'hooks', 'pre-revprop-change')
         with open(hook_path, 'w') as fd:
             fd.writelines(['#!/bin/sh\n', 'exit 0'])
         call('chmod 755 ' + hook_path)
         call('svnsync init file://%s %s' % (svn_mirror, self.remote_url))
Ejemplo n.º 6
0
    def cleanup(self):
        if not os.path.isdir(path(self.config.git_cleaned, self.svn_repo)):
            call('mkdir -p %s' % path(self.config.git_cleaned, self.svn_repo))

        svn_mirror = path(self.config.svn_mirror, self.svn_repo, self.name)
        svn_export = path(self.config.svn_export, self.svn_repo, self.name)
        git_cleaned = path(self.config.git_cleaned, self.svn_repo, self.name)

        if not os.path.isdir(svn_export):
            return

        #svn_repo_projects = dict(config.items(svn_repo))
        svn_repos = dict()
        for svn_repo in self.config.svn_repos:
            svn_repos[svn_repo.name] = svn_repo

        if os.path.isdir(git_cleaned):
            # be 100% that we are deleting something from git_cleaned folder
            if git_cleaned.startswith(self.config.git_cleaned):
                call('rm -rf %s' % git_cleaned)

        header('Cleaning: %s' % self.name)
        shutil.copytree(svn_export, git_cleaned)

        ## remove tags with revision specific information in them
        for tag in call('git tag -l', cwd=git_cleaned,
                        stdout=PIPE).split('\n'):
            if '@' in tag:
                call('git tag -d ' + tag.strip(), cwd=git_cleaned)

        ## get a list of svn/git branches
        svn_branches = [ item.strip().rstrip('/')
                for item in call('svn ls file://%s/%s%s/branches' % \
                    (self.config.svn_mirror, self.svn_repo, self.svn_path),
                    stdout=PIPE).split('\n') if item.strip() ]
        git_branches = [
            item.strip().replace('* ', '')
            for item in call('git branch --no-color',
                             cwd=git_cleaned,
                             stdout=PIPE).split('\n') if item.strip()
        ]

        ## remove branches
        for git_branch in ((set(git_branches) - set(svn_branches)) \
                - set(['master'])):
            if self.config.version_regex.match(git_branch) is None:
                call('git branch -D %s' % git_branch, cwd=git_cleaned)

        call('git gc --aggressive --prune=now --quiet', cwd=git_cleaned)
        call('git remote add origin [email protected]:%s/%s.git' %
             (self.git_org, self.name),
             cwd=git_cleaned)
Ejemplo n.º 7
0
 def sync(self):
     header('Syncing %s repository.' % self.name)
     svn_mirror = path(self.config.svn_mirror, self.name)
     call('svn propget svn:sync-last-merged-rev --revprop -r 0 file://%s' %
          svn_mirror)
     call('svnsync --non-interactive sync file://%s' % svn_mirror)
     call('svnadmin pack %s' % svn_mirror)
Ejemplo n.º 8
0
    def cleanup(self):
        if not os.path.isdir(path(self.config.git_cleaned, self.svn_repo)):
            call('mkdir -p %s' % path(self.config.git_cleaned, self.svn_repo))

        svn_mirror = path(self.config.svn_mirror, self.svn_repo, self.name)
        svn_export = path(self.config.svn_export, self.svn_repo, self.name)
        git_cleaned = path(self.config.git_cleaned, self.svn_repo, self.name)

        if not os.path.isdir(svn_export):
            return

        #svn_repo_projects = dict(config.items(svn_repo))
        svn_repos = dict()
        for svn_repo in self.config.svn_repos:
            svn_repos[svn_repo.name] = svn_repo

        if os.path.isdir(git_cleaned):
            # be 100% that we are deleting something from git_cleaned folder
            if git_cleaned.startswith(self.config.git_cleaned):
                call('rm -rf %s' % git_cleaned)

        header('Cleaning: %s' % self.name)
        shutil.copytree(svn_export, git_cleaned)

        ## remove tags with revision specific information in them
        for tag in call('git tag -l', cwd=git_cleaned, stdout=PIPE).split('\n'):
            if '@' in tag :
                call('git tag -d ' + tag.strip(), cwd=git_cleaned)

        ## get a list of svn/git branches
        svn_branches = [ item.strip().rstrip('/')
                for item in call('svn ls file://%s/%s%s/branches' % \
                    (self.config.svn_mirror, self.svn_repo, self.svn_path),
                    stdout=PIPE).split('\n') if item.strip() ]
        git_branches = [ item.strip().replace('* ', '') for item in
                call('git branch --no-color', cwd=git_cleaned,
                    stdout=PIPE).split('\n') if item.strip() ]

        ## remove branches
        for git_branch in ((set(git_branches) - set(svn_branches)) \
                - set(['master'])):
            if self.config.version_regex.match(git_branch) is None:
                call('git branch -D %s' % git_branch, cwd=git_cleaned)

        call('git gc --aggressive --prune=now --quiet', cwd=git_cleaned)
        call('git remote add origin [email protected]:plone/%s.git' % \
                self.name, cwd=git_cleaned)
Ejemplo n.º 9
0
    def export(self, args):
        """Export from svn-mirror to git repository"""

        config = Config(args.projects_file)
        if args.svn_repos is not None:
            svn_repos_to_process = args.svn_repos.split(',')
        else:
            svn_repos_to_process = [i.name for i in config.svn_repos]

        for svn_repo in config.svn_repos:
            if svn_repo.name in svn_repos_to_process:
                svn_repo.export(path(args.authors_file), args.repos)
Ejemplo n.º 10
0
    def export(self, args):
        """Export from svn-mirror to git repository"""

        config = Config(args.projects_file)
        if args.svn_repos is not None:
            svn_repos_to_process = args.svn_repos.split(';')
        else:
            svn_repos_to_process = [i.name for i in config.svn_repos]

        for svn_repo in config.svn_repos:
            if svn_repo.name in svn_repos_to_process:
                svn_repo.export(path(args.authors_file), args.repos)
Ejemplo n.º 11
0
     def compare_content(msg, svn, git):
         line('%s "%s"(svn) vs. "%s"(git)' % (msg, svn[1], git[1]), 1)
 
         svn_path = path(self.config.analyze_path, self.name, 'svn', svn[1])
         git_path = path(self.config.analyze_path, self.name, 'git', git[1])
 
         if not os.path.isdir(svn_path):
             call('mkdir -p %s' % path(svn_path, '..'))
             call('svn export -q file://%s %s' % (svn[0], svn_path))
         if not os.path.isdir(git_path):
             call('mkdir -p %s' % path(git_path, '..'))
             call('git clone -q %s %s' % (git[0], git[1]),
                     cwd=path(git_path, '..'))
             call('git checkout -q %s' % git[1], cwd=git_path)
 
         diff = call('diff -q -r -I "\$Id.*\$" -I "\$Date.*\$" --exclude ".git" %s %s' % (svn_path, git_path), stdout=PIPE, stderr=PIPE)
         if diff:
             for i in diff.split('\n'):
                 line(i, 2)
         else:
             line("everything ok", 2)
Ejemplo n.º 12
0
    def publish(self, gh, gh_repos):
        git_cleaned = path(self.config.git_cleaned, self.svn_repo, self.name)
        if not os.path.isdir(git_cleaned):
            return
        
        gh_repo_name = 'plone/' + self.name
        if self.name in gh_repos.keys():
            if confirm('Do you want to delete "%s" repository from '
                       'github?' % gh_repo_name):
                gh.repos.delete(gh_repo_name)
                header('"%s" deleted!' % gh_repo_name)
                time.sleep(5)
            else:
                header('"%s" SKIPPED.' % gh_repo_name)
                return

        gh.repos.create(gh_repo_name)
        header('"%s" created.' % gh_repo_name)

        call('git push --all', cwd=git_cleaned)
        call('git push --tags', cwd=git_cleaned)
Ejemplo n.º 13
0
    def publish(self, gh):
        gh_repos = get_gh_repos(gh, self.git_org)
        gh_repo_name = '%s/%s' % (self.git_org, self.name)
        if self.name in gh_repos:
            if confirm('Do you want to delete "%s" repository from '
                               'github?' % gh_repo_name):
                gh.repos.delete(gh_repo_name)
                header('"%s" deleted!' % gh_repo_name)
                time.sleep(10)
            else:
                header('"%s" SKIPPED.' % gh_repo_name)
                return

        git_cleaned = path(self.config.git_cleaned, self.svn_repo, self.name)
        if not os.path.isdir(git_cleaned):
            return
        
        gh.repos.create(gh_repo_name)
        header('"%s" created.' % gh_repo_name)

        call('git push --all', cwd=git_cleaned)
        call('git push --tags', cwd=git_cleaned)
Ejemplo n.º 14
0
    def publish(self, gh):
        gh_repos = get_gh_repos(gh, self.git_org)
        gh_repo_name = '%s/%s' % (self.git_org, self.name)
        if self.name in gh_repos:
            if confirm('Do you want to delete "%s" repository from '
                       'github?' % gh_repo_name):
                gh.repos.delete(gh_repo_name)
                header('"%s" deleted!' % gh_repo_name)
                time.sleep(10)
            else:
                header('"%s" SKIPPED.' % gh_repo_name)
                return

        git_cleaned = path(self.config.git_cleaned, self.svn_repo, self.name)
        if not os.path.isdir(git_cleaned):
            return

        gh.repos.create(gh_repo_name)
        header('"%s" created.' % gh_repo_name)

        call('git push --all', cwd=git_cleaned)
        call('git push --tags', cwd=git_cleaned)
Ejemplo n.º 15
0
 def svn_all_fast_export(self):
     return path(self._raw.get('base', 'svn-all-fast-export-tool'))
Ejemplo n.º 16
0
 def __init__(self, projects_file):
     self._raw = ConfigParser.SafeConfigParser({
         'here':
         path(os.path.dirname(projects_file)),
     })
     self._raw.read(path(projects_file))
Ejemplo n.º 17
0
 def sync(self):
     header('Syncing %s repository.' % self.name)
     svn_mirror = path(self.config.svn_mirror, self.name)
     call('svn propget svn:sync-last-merged-rev --revprop -r 0 file://%s' % svn_mirror)
     call('svnsync --non-interactive sync file://%s' % svn_mirror)
     call('svnadmin pack %s' % svn_mirror)
Ejemplo n.º 18
0
 def svn_mirror(self):
     svn_mirror = path(self._raw.get('base', 'svn-mirror-location'))
     if not os.path.isdir(svn_mirror):
         call('mkdir -p %s' % svn_mirror)
     return svn_mirror
Ejemplo n.º 19
0
 def svn_export(self):
     svn_export = path(self._raw.get('base', 'svn-export-location'))
     if not os.path.isdir(svn_export):
         call('mkdir -p %s' % svn_export)
     return svn_export
Ejemplo n.º 20
0
 def git_cleaned(self):
     git_cleaned = path(self._raw.get('base', 'git-cleaned-location'))
     if not os.path.isdir(git_cleaned):
         call('mkdir -p %s' % git_cleaned)
     return git_cleaned
Ejemplo n.º 21
0
 def svn_all_fast_export(self):
     return path(self._raw.get('base', 'svn-all-fast-export-tool'))
Ejemplo n.º 22
0
 def analyze_path(self):
     analyze_path = path(self._raw.get('base', 'analyze-location'))
     if not os.path.isdir(analyze_path):
         call('mkdir -p %s' % analyze_path)
     return analyze_path
Ejemplo n.º 23
0
 def __init__(self, projects_file):
     self._raw = ConfigParser.SafeConfigParser({
             'here': path(os.path.dirname(projects_file)),
             })
     self._raw.read(path(projects_file))
Ejemplo n.º 24
0
 def svn_mirror(self):
     svn_mirror = path(self._raw.get('base', 'svn-mirror-location'))
     if not os.path.isdir(svn_mirror):
         call('mkdir -p %s' % svn_mirror)
     return svn_mirror
Ejemplo n.º 25
0
 def svn_export(self):
     svn_export = path(self._raw.get('base', 'svn-export-location'))
     if not os.path.isdir(svn_export):
         call('mkdir -p %s' % svn_export)
     return svn_export
Ejemplo n.º 26
0
 def git_cleaned(self):
     git_cleaned = path(self._raw.get('base', 'git-cleaned-location'))
     if not os.path.isdir(git_cleaned):
         call('mkdir -p %s' % git_cleaned)
     return git_cleaned
Ejemplo n.º 27
0
 def analyze_path(self):
     analyze_path = path(self._raw.get('base', 'analyze-location'))
     if not os.path.isdir(analyze_path):
         call('mkdir -p %s' % analyze_path)
     return analyze_path
Ejemplo n.º 28
0
    def analyze(self):

        def compare_items(msg, svn_items, git_items):
            line(msg)
            diff = list(set(svn_items).symmetric_difference(set(git_items)))
            if diff:
                line("svn: "+str(svn_items), 1)
                line("git: "+str(git_items), 1)
                line("diff: "+str(diff), 1)
            else:
                line("everything ok", 1)
            line("")

        def compare_content(msg, svn, git):
            line('%s "%s"(svn) vs. "%s"(git)' % (msg, svn[1], git[1]), 1)
    
            svn_path = path(self.config.analyze_path, self.name, 'svn', svn[1])
            git_path = path(self.config.analyze_path, self.name, 'git', git[1])
    
            if not os.path.isdir(svn_path):
                call('mkdir -p %s' % path(svn_path, '..'))
                call('svn export -q file://%s %s' % (svn[0], svn_path))
            if not os.path.isdir(git_path):
                call('mkdir -p %s' % path(git_path, '..'))
                call('git clone -q %s %s' % (git[0], git[1]),
                        cwd=path(git_path, '..'))
                call('git checkout -q %s' % git[1], cwd=git_path)
    
            diff = call('diff -q -r -I "\$Id.*\$" -I "\$Date.*\$" --exclude ".git" %s %s' % (svn_path, git_path), stdout=PIPE, stderr=PIPE)
            if diff:
                for i in diff.split('\n'):
                    line(i, 2)
            else:
                line("everything ok", 2)


        ## paths
        svn_mirror = path(self.config.svn_mirror, self.svn_repo) + self.svn_path
        git_cleaned = path(self.config.git_cleaned, self.svn_repo, self.name)

        if not os.path.isdir(git_cleaned):
            return

        header('Analyzing "' + self.name + '" repository')

        ## svn tags and branches
        svn_branches = [ item.strip().rstrip('/') for item in \
                call('svn ls file://%s/branches' % svn_mirror,
                    stdout=PIPE).split('\n') if item.strip() ]
        svn_tags = [ item.strip().rstrip('/') for item in \
                call('svn ls file://%s/tags' % svn_mirror,
                    stdout=PIPE).split('\n') if item.strip()]

        ## git tags and breanches
        git_branches = [ item.strip().replace('* ', '') for item in \
                call('git branch --no-color', cwd=git_cleaned,
                    stdout=PIPE).split('\n') if item.strip()]
        git_branches_without_master = list(git_branches)
        if 'master' in git_branches_without_master:
            git_branches_without_master.remove('master')
        git_tags = [ item.strip() for item in \
                call('git tag -l', cwd=git_cleaned,
                    stdout=PIPE).split('\n') if item.strip()]

        ## compare tags and branches
        compare_items('Are all tags preserved?', svn_tags, git_tags)
        compare_items('Are all branches preserved?', svn_branches,
                git_branches_without_master)

        ## compare content
        line("Does content of the GIT master matches SVN trunk?")
        compare_content('Comparing BRANCHES',
                (svn_mirror + '/trunk', 'trunk'),
                (git_cleaned, 'master'))
        for branch in set(svn_branches).intersection(set(git_branches)):
            compare_content('Comparing BRANCHES: ',
                    (svn_mirror+'/branches/'+branch, branch),
                    (git_cleaned, branch))
        for tag in set(svn_tags).intersection(set(git_tags)):
            compare_content('Comparing TAGS: ',
                    (svn_mirror+'/tags/'+tag, tag),
                    (git_cleaned, tag))
Ejemplo n.º 29
0
    def analyze(self):
        def compare_items(msg, svn_items, git_items):
            line(msg)
            diff = list(set(svn_items).symmetric_difference(set(git_items)))
            if diff:
                line("svn: " + str(svn_items), 1)
                line("git: " + str(git_items), 1)
                line("diff: " + str(diff), 1)
            else:
                line("everything ok", 1)
            line("")

        def compare_content(msg, svn, git):
            line('%s "%s"(svn) vs. "%s"(git)' % (msg, svn[1], git[1]), 1)

            svn_path = path(self.config.analyze_path, self.name, 'svn', svn[1])
            git_path = path(self.config.analyze_path, self.name, 'git', git[1])

            if not os.path.isdir(svn_path):
                call('mkdir -p %s' % path(svn_path, '..'))
                call('svn export -q file://%s %s' % (svn[0], svn_path))
            if not os.path.isdir(git_path):
                call('mkdir -p %s' % path(git_path, '..'))
                call('git clone -q %s %s' % (git[0], git[1]),
                     cwd=path(git_path, '..'))
                call('git checkout -q %s' % git[1], cwd=git_path)

            diff = call(
                'diff -q -r -I "\$Id.*\$" -I "\$Date.*\$" --exclude ".git" %s %s'
                % (svn_path, git_path),
                stdout=PIPE,
                stderr=PIPE)
            if diff:
                for i in diff.split('\n'):
                    line(i, 2)
            else:
                line("everything ok", 2)

        ## paths
        svn_mirror = path(self.config.svn_mirror,
                          self.svn_repo) + self.svn_path
        git_cleaned = path(self.config.git_cleaned, self.svn_repo, self.name)

        if not os.path.isdir(git_cleaned):
            return

        header('Analyzing "' + self.name + '" repository')

        ## svn tags and branches
        svn_branches = [ item.strip().rstrip('/') for item in \
                call('svn ls file://%s/branches' % svn_mirror,
                    stdout=PIPE).split('\n') if item.strip() ]
        svn_tags = [ item.strip().rstrip('/') for item in \
                call('svn ls file://%s/tags' % svn_mirror,
                    stdout=PIPE).split('\n') if item.strip()]

        ## git tags and breanches
        git_branches = [ item.strip().replace('* ', '') for item in \
                call('git branch --no-color', cwd=git_cleaned,
                    stdout=PIPE).split('\n') if item.strip()]
        git_branches_without_master = list(git_branches)
        if 'master' in git_branches_without_master:
            git_branches_without_master.remove('master')
        git_tags = [ item.strip() for item in \
                call('git tag -l', cwd=git_cleaned,
                    stdout=PIPE).split('\n') if item.strip()]

        ## compare tags and branches
        compare_items('Are all tags preserved?', svn_tags, git_tags)
        compare_items('Are all branches preserved?', svn_branches,
                      git_branches_without_master)

        ## compare content
        line("Does content of the GIT master matches SVN trunk?")
        compare_content('Comparing BRANCHES', (svn_mirror + '/trunk', 'trunk'),
                        (git_cleaned, 'master'))
        for branch in set(svn_branches).intersection(set(git_branches)):
            compare_content('Comparing BRANCHES: ',
                            (svn_mirror + '/branches/' + branch, branch),
                            (git_cleaned, branch))
        for tag in set(svn_tags).intersection(set(git_tags)):
            compare_content('Comparing TAGS: ',
                            (svn_mirror + '/tags/' + tag, tag),
                            (git_cleaned, tag))