À l'aide de git-svn: Tirer, de Fusionner ou de Rebase?

J'ai été la lutte contre le git/git-svn courbe d'apprentissage et la nuit dernière, dans le cadre de cette courbe d'apprentissage, j'ai fait quelque chose de très, très mauvais. Depuis, j'ai obtenu qu'il a corrigé, mais je suis l'espoir de comprendre l'erreur de mes moyens.

J'ai un dépôt svn à partir de laquelle j'ai cloné le tronc et les branches (les balises je l'ai ignoré, car nous ne travaillons pas sur ceux-ci). L'utilisation de git, j'ai créé des branches locales, pour chacune des branches que j'ai besoin de travailler avec:

$ git checkout -b trunk svn/trunk
$ git checkout -b feature1 svn/branches/development/feature1
$ git checkout -b maint svn/branches/maintenance/previous-version

J'ai fait feature1 ma branche active et fait quelques modifications avant de se dérobe pour quelques jours. Je cam de hier voulu intégrer toutes les modifications qui ont été apportées au tronc, de sorte que j'ai travaillé avec la dernière et la plus grande. Ce que j'ai fait une mise à jour complète de tous les brances tout d'abord, via git svn rebase (personne n'avait travaillé sur le feature1 branche). Avec tout jusqu'à la date de mon dépôt svn, j'ai essayé de rebase.

Avec feature1 que ma branche active, j'ai fait un "git rebase tronc" en pensant que je serais en tirant des modifications du tronc en la feature1 branche. En fait, j'ai très, très mal. Après la fusion de tous les conflits, j'ai fait un git svn dcommit et constaté que mes modifications ont été appliquées pour le tronc.

Ma première question est simplement où était le cœur d'erreur dans mon processus de pensée? Mon second est, après beaucoup de lecture et de recherches sur Google, je vois des personnes adhérant à la tire, des fusions et des rebases. Compte tenu du fait que je veux fusionner les modifications appliquées dans une succursale à l'autre branche locale, ce qui devrait que j'ai fait? Quelle est la meilleure pratique pour ce scénario?

Merci pour votre aide.