mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-07-09 03:14:30 -04:00
commit
440b578d4c
90
.travis.yml
90
.travis.yml
@ -1,90 +0,0 @@
|
|||||||
language: php
|
|
||||||
|
|
||||||
sudo: true
|
|
||||||
|
|
||||||
dist: xenial
|
|
||||||
|
|
||||||
services:
|
|
||||||
- mysql
|
|
||||||
- xvfb
|
|
||||||
|
|
||||||
# Prevent tests from taking more than 50 minutes
|
|
||||||
group: deprecated-2017Q4
|
|
||||||
|
|
||||||
php:
|
|
||||||
# - 7.3
|
|
||||||
- 7.4
|
|
||||||
# - nightly
|
|
||||||
|
|
||||||
addons:
|
|
||||||
apt:
|
|
||||||
packages:
|
|
||||||
- libonig-dev
|
|
||||||
chrome: stable
|
|
||||||
hosts:
|
|
||||||
- www.ninja.test
|
|
||||||
|
|
||||||
cache:
|
|
||||||
directories:
|
|
||||||
- vendor
|
|
||||||
- $HOME/.composer/cache
|
|
||||||
|
|
||||||
env:
|
|
||||||
global:
|
|
||||||
- COMPOSER_DISCARD_CHANGES=true
|
|
||||||
- COMPOSER_NO_INTERACTION=1
|
|
||||||
- COMPOSER_DISABLE_XDEBUG_WARN=1
|
|
||||||
|
|
||||||
before_install:
|
|
||||||
# set GitHub token and update composer
|
|
||||||
- if [ -n "$GH_TOKEN" ]; then composer config github-oauth.github.com ${GH_TOKEN}; fi;
|
|
||||||
- composer self-update 1.10.19 && composer -V
|
|
||||||
# - export USE_ZEND_ALLOC=0
|
|
||||||
- rvm use 1.9.3 --install --fuzzy
|
|
||||||
- cp .env.travis .env
|
|
||||||
|
|
||||||
install:
|
|
||||||
# install Composer dependencies
|
|
||||||
# - rm composer.lock
|
|
||||||
# these providers require referencing git commit's which cause Travis to fail
|
|
||||||
# - sed -i '/mollie/d' composer.json
|
|
||||||
# - sed -i '/2checkout/d' composer.json
|
|
||||||
- travis_retry composer install --no-interaction
|
|
||||||
|
|
||||||
before_script:
|
|
||||||
# copy configuration files
|
|
||||||
- php artisan key:generate --no-interaction
|
|
||||||
- sed -i '$a NINJA_DEV=true' .env
|
|
||||||
# create the database and user
|
|
||||||
- mysql -u root -e "create database IF NOT EXISTS ninja01;"
|
|
||||||
- mysql -u root -e "create database IF NOT EXISTS ninja02;"
|
|
||||||
- mysql -u root -e "GRANT ALL PRIVILEGES ON ninja01.* To 'ninja'@'localhost' IDENTIFIED BY 'ninja'; FLUSH PRIVILEGES;"
|
|
||||||
- mysql -u root -e "GRANT ALL PRIVILEGES ON ninja02.* To 'ninja'@'localhost' IDENTIFIED BY 'ninja'; FLUSH PRIVILEGES;"
|
|
||||||
# migrate and seed the database
|
|
||||||
- php artisan migrate --database=db-ninja-01 --seed --no-interaction
|
|
||||||
- php artisan migrate --database=db-ninja-02 --seed --no-interaction
|
|
||||||
- php artisan optimize
|
|
||||||
- npm install
|
|
||||||
- npm run production
|
|
||||||
# migrate and seed the database
|
|
||||||
# Start webserver on ninja.test:8000
|
|
||||||
# export DISPLAY=:99.0
|
|
||||||
# sh -e /etc/init.d/xvfb start
|
|
||||||
# sleep 3
|
|
||||||
# ./vendor/laravel/dusk/bin/chromedriver-linux &
|
|
||||||
- php artisan dusk:chrome-driver 80
|
|
||||||
- php artisan serve &
|
|
||||||
|
|
||||||
script:
|
|
||||||
- php ./vendor/bin/phpunit --debug --verbose --coverage-clover=coverage.xml
|
|
||||||
#- php artisan dusk
|
|
||||||
#- npm test
|
|
||||||
after_success:
|
|
||||||
- bash <(curl -s https://codecov.io/bash)
|
|
||||||
|
|
||||||
notifications:
|
|
||||||
email:
|
|
||||||
on_success: never
|
|
||||||
on_failure: change
|
|
||||||
slack:
|
|
||||||
invoiceninja: SLraaKBDvjeRuRtY9o3Yvp1b
|
|
@ -12,6 +12,7 @@
|
|||||||
namespace App\Events\Product;
|
namespace App\Events\Product;
|
||||||
|
|
||||||
use App\Models\Company;
|
use App\Models\Company;
|
||||||
|
use App\Models\Product;
|
||||||
use Illuminate\Queue\SerializesModels;
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -349,7 +349,7 @@ class MigrationController extends BaseController
|
|||||||
// StartMigration::dispatch(base_path("storage/app/public/$migration_file"), $user, $fresh_company)->delay(now()->addSeconds(5));
|
// StartMigration::dispatch(base_path("storage/app/public/$migration_file"), $user, $fresh_company)->delay(now()->addSeconds(5));
|
||||||
nlog("starting migration job");
|
nlog("starting migration job");
|
||||||
nlog($migration_file);
|
nlog($migration_file);
|
||||||
StartMigration::dispatch($migration_file, $user, $fresh_company);
|
StartMigration::dispatch($migration_file, $user, $fresh_company)->onQueue('migration');
|
||||||
// } catch (\Exception $e) {
|
// } catch (\Exception $e) {
|
||||||
// nlog($e->getMessage());
|
// nlog($e->getMessage());
|
||||||
// }
|
// }
|
||||||
|
@ -109,7 +109,7 @@ class StartMigration implements ShouldQueue
|
|||||||
throw new NonExistingMigrationFile('Migration file does not exist, or it is corrupted.');
|
throw new NonExistingMigrationFile('Migration file does not exist, or it is corrupted.');
|
||||||
}
|
}
|
||||||
|
|
||||||
Import::dispatchNow($file, $this->company, $this->user);
|
Import::dispatchNow($file, $this->company, $this->user)->onQueue('migration');
|
||||||
|
|
||||||
Storage::deleteDirectory(public_path("storage/migrations/{$filename}"));
|
Storage::deleteDirectory(public_path("storage/migrations/{$filename}"));
|
||||||
|
|
||||||
|
@ -68,6 +68,10 @@ class GeneratesCounterTest extends TestCase
|
|||||||
$this->assertEquals($date_formatted."-0001", $invoice_number);
|
$this->assertEquals($date_formatted."-0001", $invoice_number);
|
||||||
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
||||||
$this->assertEquals($date_formatted."-0002", $invoice_number);
|
$this->assertEquals($date_formatted."-0002", $invoice_number);
|
||||||
|
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
||||||
|
$this->assertEquals($date_formatted."-0003", $invoice_number);
|
||||||
|
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
||||||
|
$this->assertEquals($date_formatted."-0004", $invoice_number);
|
||||||
|
|
||||||
$settings->reset_counter_date = now($timezone->name)->format('Y-m-d');
|
$settings->reset_counter_date = now($timezone->name)->format('Y-m-d');
|
||||||
$settings->reset_counter_frequency_id = RecurringInvoice::FREQUENCY_DAILY;
|
$settings->reset_counter_frequency_id = RecurringInvoice::FREQUENCY_DAILY;
|
||||||
@ -83,6 +87,22 @@ class GeneratesCounterTest extends TestCase
|
|||||||
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
||||||
$this->assertEquals($date_formatted."-0001", $invoice_number);
|
$this->assertEquals($date_formatted."-0001", $invoice_number);
|
||||||
|
|
||||||
|
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
||||||
|
$this->assertEquals($date_formatted."-0002", $invoice_number);
|
||||||
|
|
||||||
|
$settings->reset_counter_date = now($timezone->name)->format('Y-m-d');
|
||||||
|
$settings->reset_counter_frequency_id = RecurringInvoice::FREQUENCY_DAILY;
|
||||||
|
$this->company->settings = $settings;
|
||||||
|
$this->company->save();
|
||||||
|
|
||||||
|
$this->travel(5)->days();
|
||||||
|
$date_formatted = now($timezone->name)->format('Ymd');
|
||||||
|
|
||||||
|
$invoice_number = $this->getNextInvoiceNumber($this->client->fresh(), $this->invoice->fresh());
|
||||||
|
$this->assertEquals($date_formatted."-0001", $invoice_number);
|
||||||
|
|
||||||
|
$this->travelBack();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testHasSharedCounter()
|
public function testHasSharedCounter()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user