aboutsummaryrefslogtreecommitdiffstats
path: root/library/kzykhys/git/test/PHPGit/Command/MergeCommandTest.php
blob: 2084615236cfe724d2440a8365ed0a74773e7965 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<?php

use PHPGit\Git;
use Symfony\Component\Filesystem\Filesystem;

require_once __DIR__ . '/../BaseTestCase.php';

class MergeCommandTest extends BaseTestCase
{

    public function testMerge()
    {
        $filesystem = new Filesystem();

        $git = new Git();
        $git->init($this->directory);
        $git->setRepository($this->directory);

        $filesystem->dumpFile($this->directory . '/test.txt', 'foo');
        $git->add('test.txt');
        $git->commit('master');

        $git->checkout->create('develop');
        $filesystem->dumpFile($this->directory . '/test.txt', 'bar');
        $git->add('test.txt');
        $git->commit('develop');

        $git->checkout('master');

        $this->assertEquals('foo', file_get_contents($this->directory . '/test.txt'));

        $git->merge('develop');

        $this->assertEquals('bar', file_get_contents($this->directory . '/test.txt'));
    }

    /**
     * @expectedException \PHPGit\Exception\GitException
     */
    public function testMergeFail()
    {
        $filesystem = new Filesystem();

        $git = new Git();
        $git->init($this->directory);
        $git->setRepository($this->directory);

        // branch:master
        $filesystem->dumpFile($this->directory . '/test.txt', 'foo');
        $git->add('test.txt');
        $git->commit('master');

        // branch:develop
        $git->checkout->create('develop');
        $filesystem->dumpFile($this->directory . '/test.txt', 'bar');
        $git->add('test.txt');
        $git->commit('develop');

        // branch:master
        $git->checkout('master');
        $filesystem->dumpFile($this->directory . '/test.txt', 'baz');
        $git->merge('develop');
    }

    public function testMergeAbort()
    {
        $filesystem = new Filesystem();

        $git = new Git();
        $git->init($this->directory);
        $git->setRepository($this->directory);

        // branch:master
        $filesystem->dumpFile($this->directory . '/test.txt', 'foo');
        $git->add('test.txt');
        $git->commit('master');

        // branch:develop
        $git->checkout->create('develop');
        $filesystem->dumpFile($this->directory . '/test.txt', 'bar');
        $git->add('test.txt');
        $git->commit('develop');

        // branch:master
        $git->checkout('master');
        $filesystem->dumpFile($this->directory . '/test.txt', 'baz');
        $git->add('test.txt');
        $git->commit('master');

        try {
            $git->merge('develop');
            $this->fail('$git->merge("develop") should fail');
        } catch (Exception $e) {
        }

        $git->merge->abort();

        $this->assertEquals('baz', file_get_contents($this->directory . '/test.txt'));
    }

}