Skip to content

GitLab

SlopCode se integra con su flujo de trabajo GitLab a través de su canal de CI/CD GitLab o con GitLab Duo.

En ambos casos, SlopCode se ejecutará en tus corredores GitLab.


GitLab CI

SlopCode funciona en una tubería GitLab normal. Puede integrarlo en una canalización como un componente de CI

Aquí estamos utilizando un componente CI/CD creado por la comunidad para SlopCode — nagyv/gitlab-slopcode.


Características

  • Usar configuración personalizada por trabajo: configure SlopCode con un directorio de configuración personalizado, por ejemplo ./config/#custom-directory para habilitar o deshabilitar la funcionalidad por invocación de SlopCode.
  • Configuración mínima: el componente CI configura SlopCode en segundo plano, solo necesita crear la configuración SlopCode y el mensaje inicial.
  • Flexible: el componente CI admite varias entradas para personalizar su comportamiento

Configuración

  1. Guarde su SlopCode autenticación JSON como variables de entorno de CI de tipo de archivo en Configuración > CI/CD > Variables. Asegúrate de marcarlos como “Enmascarados y ocultos”.

  2. Agregue lo siguiente a su archivo .gitlab-ci.yml.

    .gitlab-ci.yml
    include:
    - component: $CI_SERVER_FQDN/nagyv/gitlab-slopcode/slopcode@2
    inputs:
    config_dir: ${CI_PROJECT_DIR}/slopcode-config
    auth_json: $SLOPCODE_AUTH_JSON # The variable name for your SlopCode authentication JSON
    command: optional-custom-command
    message: "Your prompt here"

Para obtener más entradas y casos de uso, consulte los documentos de este componente.


GitLab Duo

SlopCode se integra con su flujo de trabajo GitLab. Mencione @slopcode en un comentario y SlopCode ejecutará tareas dentro de su canal de CI GitLab.


Características

  • Clasificación de problemas: Pídele a SlopCode que investigue un problema y te lo explique.
  • Reparar e implementar: pídale a SlopCode que solucione un problema o implemente una función. Creará una nueva rama y generará una solicitud de fusión con los cambios.
  • Seguro: SlopCode se ejecuta en tus corredores GitLab.

Configuración

SlopCode se ejecuta en su canalización de CI/CD GitLab. Esto es lo que necesitará para configurarlo:

  1. Configure su entorno GitLab

  2. Configurar CI/CD

  3. Obtenga una clave API de proveedor de modelo de IA

  4. Crea una cuenta de servicio

  5. Configurar variables CI/CD

  6. Cree un archivo de configuración de flujo, aquí hay un ejemplo:

    Configuración de flujo
    image: node:22-slim
    commands:
    - echo "Installing slopcode"
    - npm install --global slopcode
    - echo "Installing glab"
    - export GITLAB_TOKEN=$GITLAB_TOKEN_SLOPCODE
    - apt-get update --quiet && apt-get install --yes curl wget gpg git && rm --recursive --force /var/lib/apt/lists/*
    - curl --silent --show-error --location "https://raw.githubusercontent.com/upciti/wakemeops/main/assets/install_repository" | bash
    - apt-get install --yes glab
    - echo "Configuring glab"
    - echo $GITLAB_HOST
    - echo "Creating SlopCode auth configuration"
    - mkdir --parents ~/.local/share/slopcode
    - |
    cat > ~/.local/share/slopcode/auth.json << EOF
    {
    "anthropic": {
    "type": "api",
    "key": "$ANTHROPIC_API_KEY"
    }
    }
    EOF
    - echo "Configuring git"
    - git config --global user.email "slopcode@gitlab.com"
    - git config --global user.name "SlopCode"
    - echo "Testing glab"
    - glab issue list
    - echo "Running SlopCode"
    - |
    slopcode run "
    You are an AI assistant helping with GitLab operations.
    Context: $AI_FLOW_CONTEXT
    Task: $AI_FLOW_INPUT
    Event: $AI_FLOW_EVENT
    Please execute the requested task using the available GitLab tools.
    Be thorough in your analysis and provide clear explanations.
    <important>
    Please use the glab CLI to access data from GitLab. The glab CLI has already been authenticated. You can run the corresponding commands.
    If you are asked to summarize an MR or issue or asked to provide more information then please post back a note to the MR/Issue so that the user can see it.
    You don't need to commit or push up changes, those will be done automatically based on the file changes you make.
    </important>
    "
    - git checkout --branch $CI_WORKLOAD_REF origin/$CI_WORKLOAD_REF
    - echo "Checking for git changes and pushing if any exist"
    - |
    if ! git diff --quiet || ! git diff --cached --quiet || [ --not --zero "$(git ls-files --others --exclude-standard)" ]; then
    echo "Git changes detected, adding and pushing..."
    git add .
    if git diff --cached --quiet; then
    echo "No staged changes to commit"
    else
    echo "Committing changes to branch: $CI_WORKLOAD_REF"
    git commit --message "Codex changes"
    echo "Pushing changes up to $CI_WORKLOAD_REF"
    git push https://gitlab-ci-token:$GITLAB_TOKEN@$GITLAB_HOST/gl-demo-ultimate-dev-ai-epic-17570/test-java-project.git $CI_WORKLOAD_REF
    echo "Changes successfully pushed"
    fi
    else
    echo "No git changes detected, skipping push"
    fi
    variables:
    - ANTHROPIC_API_KEY
    - GITLAB_TOKEN_SLOPCODE
    - GITLAB_HOST

Puede consultar los GitLab CLI documentos de los agentes para obtener instrucciones detalladas.


Ejemplos

A continuación se muestran algunos ejemplos de cómo puede utilizar SlopCode en GitLab.

  • Explica un problema

    Agregue este comentario en una edición GitLab.

    @slopcode explain this issue

    SlopCode leerá el problema y responderá con una explicación clara.

  • Solucionar un problema

    En un problema GitLab, diga:

    @slopcode fix this

    SlopCode creará una nueva rama, implementará los cambios y abrirá una solicitud de fusión con los cambios.

  • Revisar solicitudes de fusión

    Deje el siguiente comentario sobre una solicitud de fusión GitLab.

    @slopcode review this merge request

    SlopCode revisará la solicitud de fusión y brindará comentarios.