currencyservice: fix nanos overflow due to rounding
Signed-off-by: Ahmet Alp Balkan <ahmetb@google.com>
This commit is contained in:
parent
0dc4055b82
commit
05cb7ecfb9
1 changed files with 7 additions and 2 deletions
|
@ -95,19 +95,24 @@ function convert (call, callback) {
|
|||
nanos: from.nanos / data[from.currency_code]
|
||||
});
|
||||
|
||||
euros.nanos = Math.round(euros.nanos);
|
||||
|
||||
// Convert: EUR --> to_currency
|
||||
const result = _carry({
|
||||
units: euros.units * data[request.to_code],
|
||||
nanos: euros.nanos * data[request.to_code]
|
||||
});
|
||||
result.nanos = Math.round(result.nanos);
|
||||
|
||||
result.units = Math.floor(result.units)
|
||||
result.nanos = Math.floor(result.nanos)
|
||||
result.currency_code = request.to_code;
|
||||
|
||||
console.log('Conversion request successful.');
|
||||
console.log(`Conversion request successful ${result.nanos}..${result.nanos}`);
|
||||
callback(null, result);
|
||||
});
|
||||
} catch (err) {
|
||||
console.error('Conversion request failed.');
|
||||
console.error(err);
|
||||
callback(err.message);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue