Skip to content

Commit

Permalink
Extract jinja_partials and fix CRISPRessoPooled fastp errors (pinel…
Browse files Browse the repository at this point in the history
…lolab#425)

* Updated README (#64)

* Updating README to fix argument, email, and formatting

* removing superfluous files

* Add link to CRISPRessoPro, move CRISPRessoPro section to end, and fix JSON formatting

* Remove link to CRISPRessoPro

* Replace Docker badge with link to tags

* Add bullet points to Guardrails section and improve formatting

* Fix typo and removed colons from guardrails

---------

Co-authored-by: Cole Lyman <[email protected]>

* Extract jinja_partials  (#65)

* Extract jinja_partials code

* Remove Plotly dependency from setup.py

* Fix CRISPRessoPooled flash errors (#68)

* Fix replacing flash intermediate files with fastp intermediate files

This also moves where the files are added to `files_to_remove` up to
near where they are created.

* Update to run test branch with paired end Pooled test

* Add pooled-paired-sim test to integration tests

* Replace flash and trimmomatic with fastp and remove plotly from Github Actions environment

* Change test branch back to master

---------

Co-authored-by: Trevor Martin <[email protected]>
  • Loading branch information
2 people authored and mbowcut2 committed Jun 19, 2024
1 parent 1f47485 commit 176a151
Show file tree
Hide file tree
Showing 6 changed files with 64 additions and 21 deletions.
4 changes: 1 addition & 3 deletions .github/envs/test_env.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,7 @@ channels:
- defaults
dependencies:
- pip
- trimmomatic
- flash
- fastp
- numpy
- cython
- jinja2
Expand All @@ -15,4 +14,3 @@ dependencies:
- scipy
- matplotlib
- pandas
- plotly=5.18.0
7 changes: 6 additions & 1 deletion .github/workflows/integration_tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ jobs:
with:
repository: edilytics/CRISPResso2_tests
token: ${{ secrets.ACCESS_CRISPRESSO2_TESTS }}
# ref: '<BRANCH_NAME>' // Use this to specify a branch other than master
# ref: '<BRANCH-NAME>' # Use this to specify a branch other than master

- name: Run Basic
run: |
Expand All @@ -72,6 +72,11 @@ jobs:
run: |
make pooled test
- name: Run Pooled Paired Sim
if: success() || failure()
run: |
make pooled-paired-sim test
- name: Run WGS
if: success() || failure()
run: |
Expand Down
24 changes: 10 additions & 14 deletions CRISPResso2/CRISPRessoPooledCORE.py
Original file line number Diff line number Diff line change
Expand Up @@ -516,6 +516,10 @@ def main():

if fastp_status:
raise CRISPRessoShared.FastpException('FASTP failed to run, please check the log file.')

if not args.keep_intermediate:
files_to_remove += [output_forward_filename]

info('Done!', {'percent_complete': 7})

processed_output_filename = output_forward_filename
Expand Down Expand Up @@ -550,6 +554,9 @@ def main():
if args.debug:
info('Fastp command: {0}'.format(fastp_cmd))

if not args.keep_intermediate:
files_to_remove += [processed_output_filename, not_combined_1_filename, not_combined_2_filename]

if fastp_status:
raise CRISPRessoShared.FastpException('Fastp failed to run, please check the log file.')
crispresso2_info['running_info']['fastp_command'] = fastp_cmd
Expand All @@ -566,6 +573,9 @@ def main():
info(f'Forced {num_reads_force_merged} read pairs together.')
processed_output_filename = new_output_filename

if not args.keep_intermediate:
files_to_remove += [new_merged_filename, new_output_filename]

info('Done!', {'percent_complete': 7})

if can_finish_incomplete_run and 'count_input_reads' in crispresso2_info['running_info']['finished_steps']:
Expand Down Expand Up @@ -1554,20 +1564,6 @@ def default_sigpipe():
if not args.keep_intermediate:
info('Removing Intermediate files...')

if not args.aligned_pooled_bam:
if args.fastq_r2!='':
files_to_remove+=[processed_output_filename, flash_hist_filename, flash_histogram_filename,\
flash_not_combined_1_filename, flash_not_combined_2_filename]
if args.force_merge_pairs:
files_to_remove.append(new_merged_filename)
files_to_remove.append(old_flashed_filename)
else:
files_to_remove+=[processed_output_filename]

if args.trim_sequences and args.fastq_r2!='':
files_to_remove+=[output_forward_paired_filename, output_reverse_paired_filename,\
output_forward_unpaired_filename, output_reverse_unpaired_filename]

if RUNNING_MODE=='ONLY_GENOME' or RUNNING_MODE=='AMPLICONS_AND_GENOME':
if args.aligned_pooled_bam is None:
files_to_remove+=[bam_filename_genome]
Expand Down
2 changes: 1 addition & 1 deletion CRISPResso2/CRISPRessoReports/CRISPRessoReport.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

import os
from jinja2 import Environment, FileSystemLoader, ChoiceLoader, make_logging_undefined
from jinja_partials import generate_render_partial, render_partial
from CRISPResso2.CRISPRessoReports.jinja_partials import generate_render_partial, render_partial
from CRISPResso2 import CRISPRessoShared

if CRISPRessoShared.is_C2Pro_installed():
Expand Down
46 changes: 46 additions & 0 deletions CRISPResso2/CRISPRessoReports/jinja_partials.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
'''
This file is derived from https://github.com/mikeckennedy/jinja_partials and is subject to the following license:
MIT License
Copyright (c) 2021 Michael Kennedy
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
'''

from functools import partial

from markupsafe import Markup


def render_partial(template_name, renderer=None, markup=True, **data):
if renderer is None:
if flask is None:
raise PartialsException('No renderer specified')
else:
renderer = flask.render_template

if markup:
return Markup(renderer(template_name, **data))

return renderer(template_name, **data)


def generate_render_partial(renderer, markup=True):
return partial(render_partial, renderer=renderer, markup=markup)
2 changes: 0 additions & 2 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,10 +89,8 @@ def main():
'matplotlib', # '>=1.3.1,<=2.2.3',
'seaborn', # '>0.7.1,<0.10',
'jinja2',
'jinja_partials',
'scipy',
'numpy',
'plotly',
],
cmdclass = command_classes,
ext_modules = ext_modules
Expand Down

0 comments on commit 176a151

Please sign in to comment.