Skip to content

Commit

Permalink
release PHP 7.2 downgraded
Browse files Browse the repository at this point in the history
  • Loading branch information
actions-user committed Oct 20, 2023
1 parent 2cecb2b commit 4069de8
Show file tree
Hide file tree
Showing 969 changed files with 84,514 additions and 5,746 deletions.
12 changes: 0 additions & 12 deletions .editorconfig

This file was deleted.

File renamed without changes.
48 changes: 16 additions & 32 deletions .github/workflows/bare_run.yaml
Original file line number Diff line number Diff line change
@@ -1,39 +1,23 @@
name: Bare Run on various PHP versions
name: Bare Run

on:
push:
tags:
- '*'
on: [pull_request, push]

jobs:
bare_run:
runs-on: ubuntu-latest
bare_run:
runs-on: ubuntu-latest

strategy:
fail-fast: false
matrix:
php_version: ['7.2', '7.3', '7.4', '8.0']
strategy:
fail-fast: false
matrix:
php_version: ['7.2', '7.3', '7.4', '8.0']

steps:
- uses: actions/checkout@v3
steps:
- uses: actions/checkout@v2

-
id: check_tag
run: |
MESSAGE=$(git tag -l --format='%(contents)' $(git describe --tags $(git rev-list --tags --max-count=1)))
if echo $MESSAGE | grep -q "PHP 7.2 downgraded"; then
echo "NEEDED_DOWNGRADE=1" >> $GITHUB_ENV
else
echo "NEEDED_DOWNGRADE=0" >> $GITHUB_ENV
fi
-
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php_version }}
coverage: none

-
name: Setup PHP And Run Monorepo
if: env.NEEDED_DOWNGRADE == '1'
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php_version }}
coverage: none
-
if: env.NEEDED_DOWNGRADE == '1'
run: php bin/monorepo-builder list --ansi
- run: php bin/monorepo-builder list --ansi
3 changes: 0 additions & 3 deletions .gitignore

This file was deleted.

111 changes: 69 additions & 42 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ composer require symplify/monorepo-builder --dev

## Usage

### 1. Are you New to Monorepo?
### 0. Are you New to Monorepo?

The best to lean-in fast is to read basic intro at blog post [All You Always Wanted to Know About Monorepo](https://www.tomasvotruba.com/blog/2019/10/28/all-you-always-wanted-to-know-about-monorepo-but-were-afraid-to-ask/#what-is-monorepo).
We also made a simple command to make that easy for you:
Expand All @@ -25,7 +25,7 @@ vendor/bin/monorepo-builder init

And the basic setup is done!

### 2. Merge local `composer.json` to the Root One
### 1. Merge local `composer.json` to the Root One

Merges configured sections to the root `composer.json`, so you can only edit `composer.json` of particular packages and let script to synchronize it.

Expand All @@ -49,9 +49,9 @@ vendor/bin/monorepo-builder merge
Typical location for packages is `/packages`. But what if you have different naming or extra `/projects` directory?

```php
use Symplify\MonorepoBuilder\ComposerJsonManipulator\ValueObject\ComposerJsonSection;
// monorepo-builder.php
use Symplify\ComposerJsonManipulator\ValueObject\ComposerJsonSection;
use Symplify\MonorepoBuilder\Config\MBConfig;
use Symplify\MonorepoBuilder\ValueObject\Option;

return static function (MBConfig $mbConfig): void {
// where are the packages located?
Expand All @@ -62,7 +62,7 @@ return static function (MBConfig $mbConfig): void {
__DIR__ . '/projects',
]);

// how to skip packages in loaded directories?
// how skip packages in loaded direectories?
$mbConfig->packageDirectoriesExcludes([__DIR__ . '/packages/secret-package']);

// "merge" command related
Expand All @@ -84,31 +84,27 @@ return static function (MBConfig $mbConfig): void {
// the line is removed by key, so version is irrelevant, thus *
'phpunit/phpunit' => '*',
],
ComposerJsonSection::REPOSITORIES => [
// this will remove all repositories
Option::REMOVE_COMPLETELY,
],
]);
};
```

### 3. Bump Package Inter-dependencies
### 2. Bump Package Inter-dependencies

Let's say you release `symplify/symplify` 4.0 and you need package to depend on version `^4.0` for each other:

```bash
vendor/bin/monorepo-builder bump-interdependency "^4.0"
```

### 4. Keep Synchronized Package Version
### 3. Keep Synchronized Package Version

In synchronized monorepo, it's common to use same package version to prevent bugs and WTFs. So if one of your package uses `symfony/console` 3.4 and the other `symfony/console` 4.1, this will tell you:

```bash
vendor/bin/monorepo-builder validate
```

### 5. Keep Package Alias Up-To-Date
### 4. Keep Package Alias Up-To-Date

You can see this even if there is already version 3.0 out:

Expand All @@ -133,21 +129,23 @@ This will add alias `3.1-dev` to `composer.json` in each package.
If you prefer [`3.1.x-dev`](https://getcomposer.org/doc/articles/aliases.md#branch-alias) over default `3.1-dev`, you can configure it:

```php
use Symplify\MonorepoBuilder\Config\MBConfig;
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
use Symplify\MonorepoBuilder\ValueObject\Option;

return static function (MBConfig $mbConfig): void {
return static function (ContainerConfigurator $containerConfigurator): void {
$parameters = $containerConfigurator->parameters();
// default: "<major>.<minor>-dev"
$mbConfig->packageAliasFormat('<major>.<minor>.x-dev');
$parameters->set(Option::PACKAGE_ALIAS_FORMAT, '<major>.<minor>.x-dev');
};
```

### 6. Split Directories to Git Repositories
### 5. Split Directories to Git Repositories

Thanks to GitHub Actions, this was never simpler to set up. Use [symplify/github-action-monorepo-split](https://github.com/symplify/github-action-monorepo-split).

How to configure it? See our local setup at [.github/workflows/split_monorepo.yaml](https://github.com/danharrin/monorepo-split-github-action/blob/main/.github/workflows/split.yaml)
How to configure it? See our local setup at [.github/workflows/split_monorepo.yaml](https://github.com/symplify/symplify/blob/main/.github/workflows/split_monorepo.yaml)

### 7. Release Flow
### 6. Release Flow

When a new version of your package is released, you have to do many manual steps:

Expand All @@ -168,7 +166,9 @@ vendor/bin/monorepo-builder release v7.0
And add the following release workers to your `monorepo-builder.php`:

```php
use Symplify\MonorepoBuilder\Config\MBConfig;
// File: monorepo-builder.php

use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
use Symplify\MonorepoBuilder\Release\ReleaseWorker\AddTagToChangelogReleaseWorker;
use Symplify\MonorepoBuilder\Release\ReleaseWorker\PushNextDevReleaseWorker;
use Symplify\MonorepoBuilder\Release\ReleaseWorker\PushTagReleaseWorker;
Expand All @@ -178,35 +178,25 @@ use Symplify\MonorepoBuilder\Release\ReleaseWorker\TagVersionReleaseWorker;
use Symplify\MonorepoBuilder\Release\ReleaseWorker\UpdateBranchAliasReleaseWorker;
use Symplify\MonorepoBuilder\Release\ReleaseWorker\UpdateReplaceReleaseWorker;

return static function (MBConfig $mbConfig): void {
// release workers - in order to execute
$mbConfig->workers([
UpdateReplaceReleaseWorker::class,
SetCurrentMutualDependenciesReleaseWorker::class,
AddTagToChangelogReleaseWorker::class,
TagVersionReleaseWorker::class,
PushTagReleaseWorker::class,
SetNextMutualDependenciesReleaseWorker::class,
UpdateBranchAliasReleaseWorker::class,
PushNextDevReleaseWorker::class,
]);
};
```

These `TagVersionReleaseWorker` and `PushTagReleaseWorker` are enabled by default.
If you want to disable these default workers, you can use the following code.

```php
return static function (MBConfig $mbConfig): void {
$mbConfig->disableDefaultWorkers();
return static function (ContainerConfigurator $containerConfigurator): void {
$services = $containerConfigurator->services();

# release workers - in order to execute
$services->set(UpdateReplaceReleaseWorker::class);
$services->set(SetCurrentMutualDependenciesReleaseWorker::class);
$services->set(AddTagToChangelogReleaseWorker::class);
$services->set(TagVersionReleaseWorker::class);
$services->set(PushTagReleaseWorker::class);
$services->set(SetNextMutualDependenciesReleaseWorker::class);
$services->set(UpdateBranchAliasReleaseWorker::class);
$services->set(PushNextDevReleaseWorker::class);
};
```

You can also include your own workers. Just add services that implements `ReleaseWorkerInterface`.
Are you afraid to tag and push? Use `--dry-run` to see only descriptions:

```bash
vendor/bin/monorepo-builder release 7.0 --dry-run
vendor/bin/monorepo-builder release v7.0 --dry-run
```

Do you want to release next [patch version](https://semver.org/), e.g. current `v0.7.1` → next `v0.7.2`?
Expand All @@ -216,3 +206,40 @@ vendor/bin/monorepo-builder release patch
```

You can use `minor` and `major` too.

### 7. Set Your Own Release Flow

There is set of few default release workers - classes that implement `Symplify\MonorepoBuilder\Release\Contract\ReleaseWorker\ReleaseWorkerInterface`.

You need to register them as services. Feel free to start with default ones:

```php
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;

return static function (ContainerConfigurator $containerConfigurator): void {
$services = $containerConfigurator->services();

// release workers - in order to execute
$services->set(Symplify\MonorepoBuilder\Release\ReleaseWorker\SetCurrentMutualDependenciesReleaseWorker::class);
$services->set(Symplify\MonorepoBuilder\Release\ReleaseWorker\AddTagToChangelogReleaseWorker::class);

// you can extend with your own
$services->set(App\SendPigeonToTwitterReleaseWorker::class);

$services->set(Symplify\MonorepoBuilder\Release\ReleaseWorker\TagVersionReleaseWorker::class);
$services->set(Symplify\MonorepoBuilder\Release\ReleaseWorker\PushTagReleaseWorker::class);
$services->set(Symplify\MonorepoBuilder\Release\ReleaseWorker\SetNextMutualDependenciesReleaseWorker::class);
$services->set(Symplify\MonorepoBuilder\Release\ReleaseWorker\UpdateBranchAliasReleaseWorker::class);
$services->set(Symplify\MonorepoBuilder\Release\ReleaseWorker\PushNextDevReleaseWorker::class);
};
```

<br>

## Report Issues

In case you are experiencing a bug or want to request a new feature head over to the [Symplify monorepo issue tracker](https://github.com/symplify/symplify/issues)

## Contribute

The sources of this package are contained in the Symplify monorepo. We welcome contributions for this package on [symplify/symplify](https://github.com/symplify/symplify).
3 changes: 2 additions & 1 deletion bin/monorepo-builder
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#!/usr/bin/env php
<?php
<?php
namespace MonorepoBuilderPrefix202310;

require_once __DIR__ . '/monorepo-builder.php';
40 changes: 13 additions & 27 deletions bin/monorepo-builder.php
Original file line number Diff line number Diff line change
@@ -1,17 +1,14 @@
<?php

// decoupled in own "*.php" file, so ECS, Rector and PHPStan works out of the box here
declare (strict_types=1);
namespace MonorepoBuilderPrefix202310;

declare(strict_types=1);

use Symfony\Component\Console\Input\ArgvInput;

use MonorepoBuilderPrefix202310\Symfony\Component\Console\Input\ArgvInput;
use Symplify\MonorepoBuilder\Kernel\MonorepoBuilderKernel;
use Symplify\MonorepoBuilder\ValueObject\File;
use Symplify\SymplifyKernel\ValueObject\KernelBootAndApplicationRun;

define('__MONOREPO_BUILDER_RUNNING__', true);

use MonorepoBuilderPrefix202310\Symplify\SymplifyKernel\ValueObject\KernelBootAndApplicationRun;
\define('MonorepoBuilderPrefix202310\\__MONOREPO_BUILDER_RUNNING__', \true);
# 1. autoload
$possibleAutoloadPaths = [
// local
Expand All @@ -21,46 +18,35 @@
// monorepo
__DIR__ . '/../../../vendor/autoload.php',
];

foreach ($possibleAutoloadPaths as $possibleAutoloadPath) {
if (file_exists($possibleAutoloadPath)) {
if (\file_exists($possibleAutoloadPath)) {
require_once $possibleAutoloadPath;
break;
}
}

$scoperAutoloadFilepath = __DIR__ . '/../vendor/scoper-autoload.php';
if (file_exists($scoperAutoloadFilepath)) {
if (\file_exists($scoperAutoloadFilepath)) {
require_once $scoperAutoloadFilepath;
}


$configFiles = [];

$argvInput = new ArgvInput();
$configFile = resolveConfigFile($argvInput);
if (is_string($configFile)) {
if (\is_string($configFile)) {
$configFiles[] = $configFile;
}

$kernelBootAndApplicationRun = new KernelBootAndApplicationRun(MonorepoBuilderKernel::class, $configFiles);
$kernelBootAndApplicationRun->run();



function resolveConfigFile(ArgvInput $argvInput): ?string
function resolveConfigFile(ArgvInput $argvInput) : ?string
{
if ($argvInput->hasParameterOption(['-c', '--config'])) {
$configOption = $argvInput->getParameterOption(['-c', '--config']);
if (is_string($configOption) && file_exists($configOption)) {
return realpath($configOption);
if (\is_string($configOption) && \file_exists($configOption)) {
return \realpath($configOption);
}
}

$defaultConfigFilePath = getcwd() . '/' . File::CONFIG;
if (file_exists($defaultConfigFilePath)) {
$defaultConfigFilePath = \getcwd() . '/' . File::CONFIG;
if (\file_exists($defaultConfigFilePath)) {
return $defaultConfigFilePath;
}

return null;
}
File renamed without changes.
21 changes: 0 additions & 21 deletions build/rector-downgrade-php-72.php

This file was deleted.

3 changes: 0 additions & 3 deletions build/target-repository/.github/FUNDING.yml

This file was deleted.

Loading

0 comments on commit 4069de8

Please sign in to comment.