//-*- coding: utf-8 -*- //############################################################################ // // OpenERP, Open Source Management Solution // This module copyright (C) 2014 Therp BV (). // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as // published by the Free Software Foundation, either version 3 of the // License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . // //############################################################################ openerp.testing.section( 'python_compatibility', {dependencies: ['web.coresetup', 'web.pyeval']}, function(test) { test('basic deltas', function(instance) { openerp.web_relativedelta(instance); var eval = function(expression) { var result_domain = instance.web.pyeval.eval( 'domain', "[['a', '=', " + expression + "]]", {}, {}); return result_domain[0][2]; } var result; result = eval( "(datetime.date(2012, 12, 25) + relativedelta(days=7)).strftime('%Y-%m-%d')"); ok(result == '2013-01-01', "cross year"); result = eval( //2012 is a leap year "(datetime.date(2012, 01, 01) + relativedelta(days=366)).strftime('%Y-%m-%d')"); ok(result == '2013-01-01', "cross leap year"); result = eval( "(datetime.date(2012, 02, 01) + relativedelta(day=366)).strftime('%Y-%m-%d')"); ok(result == '2012-02-29', "absolute day"); result = eval( "(datetime.date(2012, 02, 01) + relativedelta(hours=-1)).strftime('%Y-%m-%d')"); ok(result == '2012-01-31', "negative hour"); result = eval( "(datetime.date(2012, 01, 30) + relativedelta(weekday=0)).strftime('%Y-%m-%d')"); ok(result == '2012-01-30', "weekday=MO (on monday)"); result = eval( "(datetime.date(2012, 01, 31) + relativedelta(weekday=0)).strftime('%Y-%m-%d')"); ok(result == '2012-02-06', "weekday=MO (on tuesday)"); result = eval( "(datetime.date(2012, 01, 30) + relativedelta(weeks=-1, days=1, weekday=0)).strftime('%Y-%m-%d')"); ok(result == '2012-01-30', "last monday (on monday)"); result = eval( "(datetime.date(2012, 01, 31) + relativedelta(weeks=-1, days=1, weekday=0)).strftime('%Y-%m-%d')"); ok(result == '2012-01-30', "last monday (on tuesday)"); result = eval( "(datetime.date(2012, 02, 01) + relativedelta(weeks=-1, days=1, weekday=0)).strftime('%Y-%m-%d')"); ok(result == '2012-01-30', "last monday (on wednesday)"); }); });