Si está buscando preservar las ramas existentes y confirmar el historial, esta es una forma que me funcionó.
git clone --mirror https://github.com/account/repo.git cloned-repo
cd cloned-repo
git push --mirror {URL of new (empty) repo}
# at this point only remote cloned-repo is correct, local has auto-generated repo structure with folders such as "branches" or "refs"
cd ..
rm -rf cloned-repo
git clone {URL of new (empty) repo}
# only now will you see the expected user-generated contents in local cloned-repo folder
# note: all non-master branches are avaialable, but git branch will not show them until you git checkout each of them
# to automatically checkout all remote branches use this loop:
for b in `git branch -r | grep -v -- '->'`; do git branch --track ${b##origin/} $b; done
Ahora, suponga que desea mantener sincronizados los repositorios de origen y destino durante un período de tiempo. Por ejemplo, todavía hay actividad dentro del repositorio remoto actual que desea llevar al repositorio nuevo / de reemplazo.
git clone -o old https://github.com/account/repo.git my-repo
cd my-repo
git remote add new {URL of new repo}
Para desplegar las últimas actualizaciones (suponiendo que no tenga cambios locales):
git checkout {branch(es) of interest}
git pull old
git push --all new
NB: todavía tengo que usar submódulos, así que no sé qué pasos adicionales podrían ser necesarios si los tiene.