SequenceServer lets you rapidly set up a BLAST+ server with an intuitive user interface for personal or group use.
If you use SequenceServer, please cite:
- Release date: June 2017
- Works with BLAST 2.2.30
For installation instructions and how to use SequenceServer please see https://sequenceserver.com/#installation.
If you want to run SequenceServer directly from source code, please see 'Develop and contribute' section below.
We have changed the underlying architecture so that BLAST jobs submisions are asynchronous and so that raw BLAST results are available in the browser in JSON format. Asynchronous job submission facilitates handling of BLAST searches that take a while to compute. For SequenceServer instances running on PCs or fat servers, this means not having to worry about network timeouts when running searches that take more than 5-10 minutes. However, asynchronous job architecture also facilitates hooking SequenceServer to grid engines (e.g., qsub) to run BLAST searches that will take hours or even days. Availability of raw BLAST results (details about each query, hit, and hsps) in the browser in JSON format means that the rich ecosystem of JavaScript visualisation libraries can be used.
Key features
- Supports BLAST 2.9.0 and the new v5 BLAST database format
- Ability to import and visualise XML output from DIAMOND and older versions of BLAST+ (till 2.2.30)
- Ability to bookmark and share the results page
- Visualisations for each level of results:
- Summary overview of top hits in a circos plot
- Length distribution of hits per query
- Relative length and position of matching regions for each query-hit pair (Kablammo)
- Ability to pre-set advanced parameters for different BLAST algorithms
Beta to stable
- Fix visual bugs in reports page
- Performance optimisation
- User reported bug fixes
The new beta releases are announced on GitHub release page and on Google Group/
Development priorities are being coordinated through the following Google Doc: SequenceServer 2.0 roadmap (comments welcome)
To get the latest 2.0 (beta) release, run:
gem install --pre sequenceserver
If you are new to the above command, please consult the 'Install or update' section on our website http://sequenceserver.com.
If you want to run SequenceServer beta directly from source code, please see 'Develop and contribute' section below.
To develop and contribute, you will need to run SequenceServer from source.
You will need Ruby and RubyGems:
# Install bundler gem to install Ruby dependencies
gem install bundler
# Move to where you downloaded or cloned seqserv
cd sequenceserver
# Use bundler to install Ruby dependencies
bundle install
# Use bundler to run SequenceServer
bundle exec bin/sequenceserver
If you do not plan to develop, you can skip installing development dependencies
by running bundle install --without=development
.
During development, you should use -D
option to run SequenceServer in development mode. In this mode, SequenceServer logs verbosely and uses raw front-end files.
# Run SequenceServer in development mode
bundle exec bin/sequenceserver -D
You will need Node and npm if you want to modify and build frontend code:
# Install frontend dependencies
npm install
# Build minified JS and CSS bundles
npm run-script build
We use RSpec and Capybara for testing. Our test suite covers 95% of the codebase. Running all tests can take considerable time (~2 hrs). We recommend using Travis to automatically run all tests when you push your code to your fork. Tests are also run automatically when you open a pull-request (see Getting code merged section below). Although, it may be desirable sometimes to run a single test, whole file, or all tests locally.
To run a single test (a.k.a, scenario):
bundle exec rspec spec/foo_spec.rb -e 'bar'
To run all tests in a single file:
bundle exec rspec spec/foo_spec.rb
To run all tests:
bundle exec rspec spec/**/*spec*
Please open a pull-request on GitHub to get code merged. Our test suite and the CodeClimate static code analysis system will be automatically run on your pull-request. These should pass for your code to be merged. If you want to add a new feature to SequenceServer, please also add tests. In addition, code should be rubocop
and eslint
compliant, and hard-wrapped to 80 chars per line.
If you change frontend code (JavaScript and CSS), please build (i.e., minify and compress) and commit the resulting JS and CSS bundles before opening a pull-request. This is because SequenceServer is run in production mode by the test suite.
Both the old stable and new beta versions of SequenceServer are available as Docker images.
# With database fasta files inside a folder named db
docker run --rm -ti -p 4567:4567 -v $(pwd)/db:/db wurmlab/sequenceserver
This will use the new beta release of SequenceServer. To use the old stable release, add the version tag to the command:
# With database fasta files inside a folder named db
docker run --rm -ti -p 4567:4567 -v $(pwd)/db:/db wurmlab/sequenceserver:1.0.11
- Anurag Priyam (architect) - email | @yeban
- Yannick Wurm (PI) - email | @yannick__
- Mailing list / forum