Coder Social home page Coder Social logo

dxr-infra's Introduction

DXR build system

DXR is a code search and navigation tool aimed at making sense of large projects like Firefox.

This repo contains:

  • Ansible configuration to manage the DXR build and web app infrastructure
  • Docker configuration for images used to index trees
  • Jenkins Job Builder templates and configuration
  • Tools to generate the running environment and configurations for the above

Prerequisites and setup

  • docker/boot2docker config change to increase disk space / image size - TBD if still required
  • credentials for JJB and docker

Usage

Using the Docker images to test builds

TODO: Review and update

  • fork repo
  • add tree to config.yml
    • restrictions: tree names can't contain "[:/]" due to Elasticsearch and jenkins-job-builder internals
  • run create-config.py to generate new dxr.config and jobs.yml files
  • build and run docker image -- edit dxr.config in running image and add tree entry from above -- change Elasticsearch settings to point at local instance
  • index the new tree
  • commit any changes and submit a PR

Managing Docker images

  • Add a new image: TBA
  • Building or updating and image: cd docker && ./build <image>
  • Publishing an image: docker push $(cat REGISTRY)/<image>/$(cat <image>/VERSION)

Using Ansible to manage the infrastructure

  • Update dxr.config on production and staging web heads: cd ansible && ansible-playbook dxr.yml -i hosts -l dxradm*

Using jenkins-job-builder to manage Jenkins

  • Run jenkins-job in test mode to verify output, supplying the tree to test: jenkins-jobs --conf credentials/jjb.ini test jjb/defaults.yml:jjb/jobs.yml newtree_index

  • Update Jenkins with the new job: jenkins-jobs --conf credentials/jjb.ini update jjb/defaults.yml:jjb/jobs.yml newtree_index

  • Update all jobs: jenkins-jobs --conf credentials/jjb.ini update jjb/defaults.yml:jjb/jobs.yml

  • Delete a Jenkins job: jenkins-jobs --conf credentials/jjb.ini delete jjb/defaults.yml:jjb/jobs.yml newtree_index

Troubleshooting

TODO:

Contributing

  1. Fork it!
  2. Create your feature branch: git checkout -b my-new-feature
  3. Commit your changes: git commit -am 'Add some feature'
  4. Push to the branch: git push origin my-new-feature
  5. Submit a pull request :D

License

This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.