Skip to content

Commit

Permalink
Test failure: Recompute fixingDays after add/subtract 10 years (#1925)
Browse files Browse the repository at this point in the history
  • Loading branch information
lballabio authored Mar 5, 2024
2 parents 589b042 + 368c13b commit 028c76e
Showing 1 changed file with 7 additions and 6 deletions.
13 changes: 7 additions & 6 deletions test-suite/convertiblebonds.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ struct CommonVars {
Calendar calendar;
DayCounter dayCounter;
Frequency frequency;
Natural settlementDays;
Natural settlementDays, fixingDays;

RelinkableHandle<Quote> underlying;
RelinkableHandle<YieldTermStructure> dividendYield, riskFreeRate;
Expand All @@ -78,10 +78,12 @@ struct CommonVars {
frequency = Annual;
settlementDays = 3;

issueDate = calendar.advance(today,2,Days);
fixingDays = 2;
issueDate = calendar.advance(today, fixingDays, Days);
maturityDate = calendar.advance(issueDate, 10, Years);
// reset to avoid inconsistencies as the schedule is backwards
issueDate = calendar.advance(maturityDate, -10, Years);
fixingDays = calendar.businessDaysBetween(today, issueDate);

underlying.linkTo(ext::make_shared<SimpleQuote>(50.0));
dividendYield.linkTo(flatRate(today, 0.02, dayCounter));
Expand Down Expand Up @@ -231,22 +233,21 @@ BOOST_AUTO_TEST_CASE(testBond) {

ext::shared_ptr<IborIndex> index =
ext::make_shared<Euribor1Y>(discountCurve);
Natural fixingDays = 2;
std::vector<Real> gearings(1, 1.0);
std::vector<Rate> spreads;

ConvertibleFloatingRateBond euFloating(euExercise, vars.conversionRatio,
vars.no_callability,
vars.issueDate, vars.settlementDays,
index, fixingDays, spreads,
index, vars.fixingDays, spreads,
vars.dayCounter, schedule,
vars.redemption);
euFloating.setPricingEngine(engine);

ConvertibleFloatingRateBond amFloating(amExercise, vars.conversionRatio,
vars.no_callability,
vars.issueDate, vars.settlementDays,
index, fixingDays, spreads,
index, vars.fixingDays, spreads,
vars.dayCounter, schedule,
vars.redemption);
amFloating.setPricingEngine(engine);
Expand All @@ -261,7 +262,7 @@ BOOST_AUTO_TEST_CASE(testBond) {
DateGeneration::Backward, false);

FloatingRateBond floating(vars.settlementDays, vars.faceAmount, floatSchedule,
index, vars.dayCounter, Following, fixingDays,
index, vars.dayCounter, Following, vars.fixingDays,
gearings, spreads,
std::vector<Rate>(), std::vector<Rate>(),
false,
Expand Down

0 comments on commit 028c76e

Please sign in to comment.