mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-05-24 02:14:21 -04:00
Use travel to move timezones
This commit is contained in:
parent
f5cdf07d78
commit
ebdf25e1a8
@ -418,8 +418,6 @@ class RecurringInvoice extends BaseModel
|
|||||||
|
|
||||||
$offset = $this->client->timezone_offset();
|
$offset = $this->client->timezone_offset();
|
||||||
|
|
||||||
nlog("offset = {$offset}");
|
|
||||||
|
|
||||||
/* If this setting is enabled, the recurring invoice may be set in the past */
|
/* If this setting is enabled, the recurring invoice may be set in the past */
|
||||||
|
|
||||||
if ($this->company->stop_on_unpaid_recurring) {
|
if ($this->company->stop_on_unpaid_recurring) {
|
||||||
|
@ -45,6 +45,186 @@ class RecurringDatesTest extends TestCase
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function testDailyFrequencyCalc6()
|
||||||
|
{
|
||||||
|
$this->travelTo(now()->subHours(8));
|
||||||
|
|
||||||
|
$account = Account::factory()->create();
|
||||||
|
|
||||||
|
$settings = CompanySettings::defaults();
|
||||||
|
$settings->entity_send_time = '1';
|
||||||
|
$settings->timezone_id = '113';
|
||||||
|
|
||||||
|
$company = Company::factory()->create([
|
||||||
|
'account_id' => $account->id,
|
||||||
|
'settings' => $settings,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$account->default_company_id = $company->id;
|
||||||
|
$account->save();
|
||||||
|
|
||||||
|
$user = User::factory()->create([
|
||||||
|
'account_id' => $account->id,
|
||||||
|
'confirmation_code' => $this->createDbHash(config('database.default')),
|
||||||
|
'email' => 'whiz@gmail.com',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$userPermissions = collect([
|
||||||
|
'view_invoice',
|
||||||
|
'view_client',
|
||||||
|
'edit_client',
|
||||||
|
'edit_invoice',
|
||||||
|
'create_invoice',
|
||||||
|
'create_client',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$userSettings = DefaultSettings::userSettings();
|
||||||
|
|
||||||
|
$user->companies()->attach($company->id, [
|
||||||
|
'account_id' => $account->id,
|
||||||
|
'is_owner' => 1,
|
||||||
|
'is_admin' => 1,
|
||||||
|
'notifications' => CompanySettings::notificationDefaults(),
|
||||||
|
'permissions' => $userPermissions->toJson(),
|
||||||
|
'settings' => json_encode($userSettings),
|
||||||
|
'is_locked' => 0,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$client = Client::factory()->create(['user_id' => $user->id, 'company_id' => $company->id]);
|
||||||
|
|
||||||
|
ClientContact::factory()->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'client_id' => $client->id,
|
||||||
|
'company_id' => $company->id,
|
||||||
|
'is_primary' => 1,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$recurring_invoice = RecurringInvoice::factory()->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'company_id' => $company->id,
|
||||||
|
'client_id' => $client->id,
|
||||||
|
'frequency_id' => RecurringInvoice::FREQUENCY_DAILY,
|
||||||
|
'next_send_date' => now()->format('Y-m-d'),
|
||||||
|
'next_send_date_client' => now()->format('Y-m-d'),
|
||||||
|
'date' => now()->format('Y-m-d'),
|
||||||
|
'remaining_cycles' => -1,
|
||||||
|
'status_id' => 1,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$recurring_invoice->service()->start()->save();
|
||||||
|
|
||||||
|
$this->assertEquals('1', $client->getSetting('entity_send_time'));
|
||||||
|
$this->assertEquals('113', $client->getSetting('timezone_id'));
|
||||||
|
|
||||||
|
$this->assertEquals(now()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date)->format('Y-m-d'));
|
||||||
|
$this->assertEquals(now()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date_client)->format('Y-m-d'));
|
||||||
|
|
||||||
|
$recurring_invoice->next_send_date = $recurring_invoice->nextSendDate();
|
||||||
|
$recurring_invoice->next_send_date_client = $recurring_invoice->nextSendDateClient();
|
||||||
|
$recurring_invoice->save();
|
||||||
|
|
||||||
|
$this->assertEquals(now()->startOfDay()->addDay()->addSeconds($client->timezone_offset()), Carbon::parse($recurring_invoice->next_send_date));
|
||||||
|
$this->assertEquals(now()->addDay()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date_client)->format('Y-m-d'));
|
||||||
|
|
||||||
|
$recurring_invoice->next_send_date = $recurring_invoice->nextSendDate();
|
||||||
|
$recurring_invoice->next_send_date_client = $recurring_invoice->nextSendDateClient();
|
||||||
|
$recurring_invoice->save();
|
||||||
|
|
||||||
|
$this->assertEquals(now()->startOfDay()->addDays(2)->addSeconds($client->timezone_offset()), Carbon::parse($recurring_invoice->next_send_date));
|
||||||
|
$this->assertEquals(now()->addDays(2)->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date_client)->format('Y-m-d'));
|
||||||
|
|
||||||
|
$this->travelBack();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public function testDailyFrequencyCalc5()
|
||||||
|
{
|
||||||
|
|
||||||
|
$account = Account::factory()->create();
|
||||||
|
|
||||||
|
$settings = CompanySettings::defaults();
|
||||||
|
$settings->entity_send_time = '23';
|
||||||
|
$settings->timezone_id = '113';
|
||||||
|
|
||||||
|
$company = Company::factory()->create([
|
||||||
|
'account_id' => $account->id,
|
||||||
|
'settings' => $settings,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$account->default_company_id = $company->id;
|
||||||
|
$account->save();
|
||||||
|
|
||||||
|
$user = User::factory()->create([
|
||||||
|
'account_id' => $account->id,
|
||||||
|
'confirmation_code' => $this->createDbHash(config('database.default')),
|
||||||
|
'email' => 'whiz@gmail.com',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$userPermissions = collect([
|
||||||
|
'view_invoice',
|
||||||
|
'view_client',
|
||||||
|
'edit_client',
|
||||||
|
'edit_invoice',
|
||||||
|
'create_invoice',
|
||||||
|
'create_client',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$userSettings = DefaultSettings::userSettings();
|
||||||
|
|
||||||
|
$user->companies()->attach($company->id, [
|
||||||
|
'account_id' => $account->id,
|
||||||
|
'is_owner' => 1,
|
||||||
|
'is_admin' => 1,
|
||||||
|
'notifications' => CompanySettings::notificationDefaults(),
|
||||||
|
'permissions' => $userPermissions->toJson(),
|
||||||
|
'settings' => json_encode($userSettings),
|
||||||
|
'is_locked' => 0,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$client = Client::factory()->create(['user_id' => $user->id, 'company_id' => $company->id]);
|
||||||
|
|
||||||
|
ClientContact::factory()->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'client_id' => $client->id,
|
||||||
|
'company_id' => $company->id,
|
||||||
|
'is_primary' => 1,
|
||||||
|
]);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$recurring_invoice = RecurringInvoice::factory()->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'company_id' => $company->id,
|
||||||
|
'client_id' => $client->id,
|
||||||
|
'frequency_id' => RecurringInvoice::FREQUENCY_DAILY,
|
||||||
|
'next_send_date' => now()->format('Y-m-d'),
|
||||||
|
'next_send_date_client' => now()->format('Y-m-d'),
|
||||||
|
'date' => now()->format('Y-m-d'),
|
||||||
|
'remaining_cycles' => -1,
|
||||||
|
'status_id' => 1,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$recurring_invoice->service()->start()->save();
|
||||||
|
|
||||||
|
$this->assertEquals('23', $client->getSetting('entity_send_time'));
|
||||||
|
$this->assertEquals('113', $client->getSetting('timezone_id'));
|
||||||
|
|
||||||
|
$this->assertEquals(now()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date)->format('Y-m-d'));
|
||||||
|
$this->assertEquals(now()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date_client)->format('Y-m-d'));
|
||||||
|
|
||||||
|
$recurring_invoice->next_send_date = $recurring_invoice->nextSendDate();
|
||||||
|
$recurring_invoice->next_send_date_client = $recurring_invoice->nextSendDateClient();
|
||||||
|
$recurring_invoice->save();
|
||||||
|
|
||||||
|
$this->assertEquals(now()->startOfDay()->addDay()->addSeconds($client->timezone_offset()), Carbon::parse($recurring_invoice->next_send_date));
|
||||||
|
$this->assertEquals(now()->addDay()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date_client)->format('Y-m-d'));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public function testDailyFrequencyCalc4()
|
public function testDailyFrequencyCalc4()
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -369,9 +549,6 @@ class RecurringDatesTest extends TestCase
|
|||||||
$recurring_invoice->next_send_date_client = $recurring_invoice->nextSendDateClient();
|
$recurring_invoice->next_send_date_client = $recurring_invoice->nextSendDateClient();
|
||||||
$recurring_invoice->save();
|
$recurring_invoice->save();
|
||||||
|
|
||||||
nlog($recurring_invoice->next_send_date);
|
|
||||||
nlog($recurring_invoice->next_send_date_client);
|
|
||||||
|
|
||||||
$this->assertEquals(now()->startOfDay()->addDay()->addSeconds($client->timezone_offset()), Carbon::parse($recurring_invoice->next_send_date));
|
$this->assertEquals(now()->startOfDay()->addDay()->addSeconds($client->timezone_offset()), Carbon::parse($recurring_invoice->next_send_date));
|
||||||
$this->assertEquals(now()->addDay()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date_client)->format('Y-m-d'));
|
$this->assertEquals(now()->addDay()->format('Y-m-d'), Carbon::parse($recurring_invoice->next_send_date_client)->format('Y-m-d'));
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user