Sign TO in post route
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
import datetime
|
||||||
from flask import current_app as app
|
from flask import current_app as app
|
||||||
|
|
||||||
from atst.database import db
|
from atst.database import db
|
||||||
@@ -47,6 +48,16 @@ class TaskOrders(BaseDomainClass):
|
|||||||
|
|
||||||
return task_order
|
return task_order
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def sign(cls, task_order, signer_dod_id):
|
||||||
|
task_order.signer_dod_id = signer_dod_id
|
||||||
|
task_order.signed_at = datetime.datetime.now()
|
||||||
|
|
||||||
|
db.session.add(task_order)
|
||||||
|
db.session.commit()
|
||||||
|
|
||||||
|
return task_order
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def create_clins(cls, task_order_id, clin_list):
|
def create_clins(cls, task_order_id, clin_list):
|
||||||
for clin_data in clin_list:
|
for clin_data in clin_list:
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
from datetime import timedelta
|
||||||
from enum import Enum
|
from enum import Enum
|
||||||
|
|
||||||
from sqlalchemy import Column, DateTime, ForeignKey, String
|
from sqlalchemy import Column, DateTime, ForeignKey, String
|
||||||
@@ -100,7 +101,8 @@ class TaskOrder(Base, mixins.TimestampsMixin):
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def end_date(self):
|
def end_date(self):
|
||||||
return max((c.end_date for c in self.clins), default=None)
|
default_end_date = self.start_date + timedelta(days=1)
|
||||||
|
return max((c.end_date for c in self.clins), default=default_end_date)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def days_to_expiration(self):
|
def days_to_expiration(self):
|
||||||
|
@@ -1,5 +1,3 @@
|
|||||||
from datetime import date
|
|
||||||
|
|
||||||
from flask import g, render_template, url_for, redirect
|
from flask import g, render_template, url_for, redirect
|
||||||
|
|
||||||
from . import task_orders_bp
|
from . import task_orders_bp
|
||||||
@@ -42,7 +40,10 @@ def review_task_order(task_order_id):
|
|||||||
@task_orders_bp.route("/task_orders/<task_order_id>/submit", methods=["POST"])
|
@task_orders_bp.route("/task_orders/<task_order_id>/submit", methods=["POST"])
|
||||||
@user_can(Permissions.CREATE_TASK_ORDER, "submit task order")
|
@user_can(Permissions.CREATE_TASK_ORDER, "submit task order")
|
||||||
def submit_task_order(task_order_id):
|
def submit_task_order(task_order_id):
|
||||||
|
|
||||||
task_order = TaskOrders.get(task_order_id)
|
task_order = TaskOrders.get(task_order_id)
|
||||||
|
TaskOrders.sign(task_order=task_order, signer_dod_id=g.current_user.dod_id)
|
||||||
|
|
||||||
flash("task_order_submitted", task_order=task_order)
|
flash("task_order_submitted", task_order=task_order)
|
||||||
|
|
||||||
return redirect(
|
return redirect(
|
||||||
@@ -56,11 +57,11 @@ def portfolio_funding(portfolio_id):
|
|||||||
portfolio = Portfolios.get(g.current_user, portfolio_id)
|
portfolio = Portfolios.get(g.current_user, portfolio_id)
|
||||||
task_orders = TaskOrders.sort(portfolio.task_orders)
|
task_orders = TaskOrders.sort(portfolio.task_orders)
|
||||||
label_colors = {
|
label_colors = {
|
||||||
Status.DRAFT: "warning",
|
TaskOrderStatus.DRAFT: "warning",
|
||||||
Status.ACTIVE: "success",
|
TaskOrderStatus.ACTIVE: "success",
|
||||||
Status.UPCOMING: "info",
|
TaskOrderStatus.UPCOMING: "info",
|
||||||
Status.EXPIRED: "error",
|
TaskOrderStatus.EXPIRED: "error",
|
||||||
Status.UNSIGNED: "purple",
|
TaskOrderStatus.UNSIGNED: "purple",
|
||||||
}
|
}
|
||||||
return render_template(
|
return render_template(
|
||||||
"portfolios/task_orders/index.html",
|
"portfolios/task_orders/index.html",
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
from datetime import date
|
||||||
from flask import url_for
|
from flask import url_for
|
||||||
import pytest
|
import pytest
|
||||||
from datetime import timedelta, date
|
from datetime import timedelta, date
|
||||||
@@ -6,16 +7,10 @@ from atst.domain.permission_sets import PermissionSets
|
|||||||
from atst.domain.task_orders import TaskOrders
|
from atst.domain.task_orders import TaskOrders
|
||||||
from atst.models import *
|
from atst.models import *
|
||||||
from atst.models.portfolio_role import Status as PortfolioStatus
|
from atst.models.portfolio_role import Status as PortfolioStatus
|
||||||
|
from atst.models.task_order import Status as TaskOrderStatus
|
||||||
from atst.utils.localization import translate
|
from atst.utils.localization import translate
|
||||||
|
|
||||||
from tests.factories import (
|
from tests.factories import *
|
||||||
PortfolioFactory,
|
|
||||||
PortfolioRoleFactory,
|
|
||||||
TaskOrderFactory,
|
|
||||||
UserFactory,
|
|
||||||
random_future_date,
|
|
||||||
random_past_date,
|
|
||||||
)
|
|
||||||
from tests.utils import captured_templates
|
from tests.utils import captured_templates
|
||||||
|
|
||||||
|
|
||||||
@@ -23,10 +18,12 @@ from tests.utils import captured_templates
|
|||||||
def portfolio():
|
def portfolio():
|
||||||
return PortfolioFactory.create()
|
return PortfolioFactory.create()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def user():
|
def user():
|
||||||
return UserFactory.create()
|
return UserFactory.create()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def task_order():
|
def task_order():
|
||||||
user = UserFactory.create()
|
user = UserFactory.create()
|
||||||
@@ -38,18 +35,37 @@ def task_order():
|
|||||||
|
|
||||||
def test_review_task_order(client, user_session, task_order):
|
def test_review_task_order(client, user_session, task_order):
|
||||||
user_session(task_order.portfolio.owner)
|
user_session(task_order.portfolio.owner)
|
||||||
response = client.get(url_for("task_orders.review_task_order", task_order_id=task_order.id))
|
response = client.get(
|
||||||
|
url_for("task_orders.review_task_order", task_order_id=task_order.id)
|
||||||
|
)
|
||||||
assert response.status_code == 200
|
assert response.status_code == 200
|
||||||
|
|
||||||
|
|
||||||
def test_submit_task_order(client, user_session, task_order):
|
def test_submit_task_order(client, user_session, task_order):
|
||||||
user_session(task_order.portfolio.owner)
|
user_session(task_order.portfolio.owner)
|
||||||
response = client.post(
|
response = client.post(
|
||||||
url_for(
|
url_for("task_orders.submit_task_order", task_order_id=task_order.id)
|
||||||
"task_orders.submit_task_order", task_order_id=task_order.id
|
|
||||||
),
|
|
||||||
)
|
)
|
||||||
assert response.status_code == 302
|
assert response.status_code == 302
|
||||||
|
|
||||||
|
active_start_date = date.today() - timedelta(days=1)
|
||||||
|
active_task_order = TaskOrderFactory(portfolio=task_order.portfolio)
|
||||||
|
CLINFactory(task_order=active_task_order, start_date=active_start_date)
|
||||||
|
assert active_task_order.status == TaskOrderStatus.UNSIGNED
|
||||||
|
response = client.post(
|
||||||
|
url_for("task_orders.submit_task_order", task_order_id=active_task_order.id)
|
||||||
|
)
|
||||||
|
assert active_task_order.status == TaskOrderStatus.ACTIVE
|
||||||
|
|
||||||
|
upcoming_start_date = date.today() + timedelta(days=1)
|
||||||
|
upcoming_task_order = TaskOrderFactory(portfolio=task_order.portfolio)
|
||||||
|
CLINFactory(task_order=upcoming_task_order, start_date=upcoming_start_date)
|
||||||
|
assert upcoming_task_order.status == TaskOrderStatus.UNSIGNED
|
||||||
|
response = client.post(
|
||||||
|
url_for("task_orders.submit_task_order", task_order_id=upcoming_task_order.id)
|
||||||
|
)
|
||||||
|
assert upcoming_task_order.status == TaskOrderStatus.UPCOMING
|
||||||
|
|
||||||
|
|
||||||
class TestPortfolioFunding:
|
class TestPortfolioFunding:
|
||||||
@pytest.mark.skip(reason="Update later when CLINs are implemented")
|
@pytest.mark.skip(reason="Update later when CLINs are implemented")
|
||||||
|
Reference in New Issue
Block a user