trac-past-commit-hook в удаленном хранилище - PullRequest
0 голосов
/ 17 июля 2009

Попытка настроить фиксацию SVN с помощью trac, используя этот скрипт.

Он вызывается без проблем, но проблема в следующем:

144 repos = self.env.get_repository()

Поскольку я вызываю это удаленно, self.env_get_repository () ищет хранилище, используя диск сервера, а не локальное сопоставление дисков. То есть он ищет E: / Projects / SVN / InfoProj, а не Y: / Projects / SV / InfoProj

Я заметил changeset в наборе trac для возможности вызова get_repository () и передачи пути в качестве переменной, но, похоже, это еще не вошло в последний стабильный выпуск.

Эта версия скрипта (представленная кодом monkey), похоже, работает по-другому, но выдает ошибку, которая кажется связанной:

154         if url is None:
155             url = self.env.config.get('project', 'url')
156         self.env.href = Href(url)
157         self.env.abs_href = Href(url)

Строка 156/157, ошибка выброса: Предупреждение: Ошибка типа: объект 'str' не вызывается

Стабильная версия сценария 10.3 выдает совершенно другую ошибку: Предупреждение: NameError: глобальное имя 'core' не определено

Я впервые настраиваю trac на коробке Windows с удаленным репозиторием. Я использую стабильную трассировку 0.11 с Python 2.6.

Я думал, что было бы намного больше людей, пытающихся совершить транзакции между серверами, которые сталкивались с этой проблемой. Я посмотрел вокруг и не смог найти решение. Я предполагаю, что у Linux есть более изящный способ справиться с этим.

Заранее спасибо.

1 Ответ

0 голосов
/ 22 июля 2009

Это полностью выполнимо и требует пары небольших взломов ... ух ты!

Проблема, с которой я столкнулся, заключается в том, что get_repository считывает значение репозитория svn из файла trac.ini. Это указывало на E: /, а не на Y: /. Простое исправление включает проверку, чтобы определить, находится ли репозиторий на repository_dir , а если нет, то проверьте новую переменную remote_repository_dir . Вторая часть исправления включает удаление сообщения об ошибке из cache.py, который проверяет, совпадает ли текущий адрес хранилища с передаваемым.

Как всегда, используйте это на свой страх и риск и сделайте резервную копию всего заранее !!!

Сначала откройте файл trac.ini и добавьте новую переменную 'remote_repository_dir' под переменной 'repository_dir'. Удаленный репозиторий dir будет указывать на подключенный диск на вашем локальном компьютере. Теперь оно должно выглядеть примерно так:

repository_dir = E:/Projects/svn/InfoProj
remote_repository_dir = Y:/Projects/svn/InfoProj 

Затем мы изменим файл api.py, чтобы проверить наличие новой переменной, если он не может найти хранилище в каталоге repository_dir . Вокруг: 71 у вас должно быть что-то вроде этого:

repository_dir = Option('trac', 'repository_dir', '',
    """Path to local repository. This can also be a relative path
    (''since 0.11'').""")

Под этой строкой добавьте:

remote_repository_dir = Option('trac', 'remote_repository_dir', '',
    """Path to remote repository.""")   

Следующая рядом: 156 у вас будет это:

            rtype, rdir = self.repository_type, self.repository_dir
            if not os.path.isabs(rdir):
                rdir = os.path.join(self.env.path, rdir)

Измените это на:

            rtype, rdir = self.repository_type, self.repository_dir
            if not os.path.isdir(rdir):
                rdir = self.remote_repository_dir
            if not os.path.isabs(rdir):
                rdir = os.path.join(self.env.path, rdir)

Наконец, вам нужно удалить предупреждение в файле cache.py (обратите внимание, что это не лучший способ сделать это, вы должны иметь возможность включить удаленную переменную как часть проверки, но пока она работает) .

В cache.py вблизи: 97 это должно выглядеть так:

    if repository_dir:
        # directory part of the repo name can vary on case insensitive fs
        if os.path.normcase(repository_dir) != os.path.normcase(self.name):
            self.log.info("'repository_dir' has changed from %r to %r"
                          % (repository_dir, self.name))
            raise TracError(_("The 'repository_dir' has changed, a "
                              "'trac-admin resync' operation is needed."))
    elif repository_dir is None: # 
        self.log.info('Storing initial "repository_dir": %s' % self.name)
        cursor.execute("INSERT INTO system (name,value) VALUES (%s,%s)",
                       (CACHE_REPOSITORY_DIR, self.name,))
    else: # 'repository_dir' cleared by a resync
        self.log.info('Resetting "repository_dir": %s' % self.name)
        cursor.execute("UPDATE system SET value=%s WHERE name=%s",
                       (self.name, CACHE_REPOSITORY_DIR))

Мы собираемся удалить первую часть оператора if, поэтому теперь она должна выглядеть следующим образом:

    if repository_dir is None: # 
        self.log.info('Storing initial "repository_dir": %s' % self.name)
        cursor.execute("INSERT INTO system (name,value) VALUES (%s,%s)",
                       (CACHE_REPOSITORY_DIR, self.name,))
    else: # 'repository_dir' cleared by a resync
        self.log.info('Resetting "repository_dir": %s' % self.name)
        cursor.execute("UPDATE system SET value=%s WHERE name=%s",
                       (self.name, CACHE_REPOSITORY_DIR))

Внимание! Это будет означать, что больше не выдает ошибку, если ваш каталог изменился и вам требуется повторная синхронизация.

Надеюсь, это кому-нибудь поможет.

...