02.

Testing the Code from a PR

Share this awesome video!

|

It looks like Colin did a great job with this new feature. But, we can give a merger much more confidence by actually testing it in a real project!

Creating a new Test App

In PhpStorm, I've already created an empty contributing directory. And, I already have a terminal open to this same place. To test the PR, let's literally create a brand-new Symfony app:

composer create-project symfony/skeleton

I'm using symfony/skeleton instead of the larger symfony/website-skeleton to keep things as small and focused as possible. Grab the dev-master version of the skeleton:

composer create-project symfony/skeleton:dev-master

Why? Colin's PR is against Symfony's master branch. So, to test it, I want to create an app that's based on that same version of Symfony.

Finally, put this into a new directory called triage_pr_28069:

composer create-project symfony/skeleton:dev-master triage_pr_28069

When that finishes, move over and... yea! Here's the new app. Check out its composer.json file:

62 lines | triage_pr_28069/composer.json
{
// ... lines 2 - 4
"require": {
// ... lines 6 - 8
"symfony/console": "^4.2",
// ... line 10
"symfony/force-lowest": "=4.2",
"symfony/framework-bundle": "^4.2",
"symfony/yaml": "^4.2"
},
"require-dev": {
"symfony/dotenv": "^4.2"
},
// ... lines 18 - 60
}

It's using version 4.2 of Symfony, which is the next, unreleased, version of Symfony at this moment. In other words, this code is from Symfony's master branch. We also have minimum-stability set to dev:

62 lines | triage_pr_28069/composer.json
{
// ... lines 2 - 3
"minimum-stability": "dev",
// ... lines 5 - 60
}

Which means that Composer will try to install new, unreleased version of libraries.

Look back at the PR: all of the changes were to the Validator component. Ok, let's get that installed: find your terminal, move into the directory and run:

composer require validator

This will install the dev-master version of symfony/validator. In other words, it will get the code from Symfony's master branch. But... hmm... that's not quite what we want: we somehow need to get the code from Colin's branch. How can we do that? Oh, it's super cool.

Getting the Code from the Pull Request

Go to your terminal and open a new tab. Go back up to the contributing directory. I'm going to clone the entire Symfony project into a new directory here. To do that, go back to your browser, move to the repository's homepage, click "Clone or download" and copy the URL.

Move back over, git clone and paste:

git clone git@github.com:symfony/symfony.git

When that finishes, we now have a symfony directory right next to our app. To get Colin's branch, we have a few options. Move into the new symfony directory:

cd symfony/

And type:

git remote

and

git remote show origin

Let's add a second remote for Colin's fork. Copy the Symfony URL, then run git remote add and paste. Copy Colin's username - colinodell, move back, call the new remote colinodell, and change the username part of the URL:

git remote add colinodell git@github.com:colinodell/symfony.git

Nice! Grab his branches with:

git fetch colinodell

Yep! There's the branch: feature/multiple-of-validator - this is the one used for the PR. To check out to that code, create a new branch:

git checkout -b feature/multiple-of-validator colinodell/feature/multiple-of-validator

Sweet! To prove we've got the right code, go back to PhpStorm, press Shift+Shift, and search for the new file. There it is!

We now have a test app and the new code in our symfony directory. But, they're not connected yet! Let's do that next.