oh-my-posh/website/docs/contributing/plastic.md
2022-05-13 08:19:35 +02:00

353 lines
8.5 KiB
Markdown

---
id: plastic
title: Setup for Plastic SCM testing
sidebar_label: Plastic SCM testing
---
When changing the `segment_plastic.go` file, you may need to test your changes against an actual instance of
[Plastic SCM][plastic]. This doc should bring you up to speed with Plastic SCM.
In the [contributing doc][contributing] there is a section about [dev containers & codespaces][devcontainer].
You can set up Plastic SCM inside these as well.
## Server Setup
Here you can find the [official setup instructions][setup-instructions]. I'll describe it in short:
### Installation on Debian or in dev-container
First add the repo:
```bash
sudo apt-get update
sudo apt-get install -y apt-transport-https
echo "deb https://www.plasticscm.com/plasticrepo/stable/debian/ ./" | sudo tee /etc/apt/sources.list.d/plasticscm-stable.list
wget https://www.plasticscm.com/plasticrepo/stable/debian/Release.key -O - | sudo apt-key add -
sudo apt-get update
```
Then install the server: *this might throw an error at the end of the setup **see below***
```bash
sudo apt-get install plasticscm-server-core
```
This might show an error while configuring the installed package. In that case the server was nod registered as a service.
**Ignore it!**
### Server configuration
Configuring the server is done via:
```bash
cd /opt/plasticscm5/server/
sudo ./plasticd configure
```
You are asked 5 questions. Choose these options:
1. **1**: English
2. 8087 (default port, **just hit return**)
3. 8088 (default ssl port, **just hit return**)
4. **1**: NameWorkingMode (use local users and groups)
5. skip license token (**just hit return**)
**Congrats!** Your server is configured. You can find out more in the [official configuration instructions][server-config].
### Run Server
If your server installed without an error, it was correctly registered as a server and can be started via:
```bash
sudo service plasticd start
```
If not, you need to start it manually (for example inside the dev-container):
```bash
cd /opt/plasticscm5/server/
sudo ./plasticd start
```
This will lock the current shell until the server process finishes. You might need to open another terminal to continue.
Your Plastic SCM server should be started now.
## Client Setup
Plastic SCM comes, much like git, with a CLI (+ client UI \[optional\])
### Installation on Debian or in dev-container
These are the steps to install the **Plastic SCM CLI** on Debian or in the dev-container:
```bash
sudo apt-get install plasticscm-client-core
```
### Client configuration
To connect the client to the server and set up an account run:
```bash
clconfigureclient
```
You are asked a few questions. Choose these options:
1. **1**: English
2. localhost (**just hit return**)
3. default port 8087 (**just hit return**)
4. No SSL (**just hit return**)
5. No Proxy (**just hit return**)
**Congrats!** Your client should now be connected to your server.
You can test if it worked and display some license info via:
```bash
cm li
```
## Testing stuff
Now to the fun part! The server is automatically set up to host a `default` repo with the branch `/main`.
The Plastic SCM CLI command is: `cm`
If you ever wonder what you can do with it call:
```bash
cm showcommands --all`
```
### Creating a local workspace
You need a local workspace to work with plastic:
```bash
cd ~
mkdir dev
cd dev
cm wk create workspace workspace rep:default
cd workspace
cm status
```
### Adding files
Start by creating local, private files
```bash
echo "test" > myfile.txt
cm status --all
```
Add the file to your local changes
```bash
cm add myfile.txt
cm status
```
**Test hint:** Both `Private` and `Added` files should be counted towards the `Added` property of the `plastic` segment.
### Commiting changes
After locally adding, changing, moving or deleting files you want to commit them to create a new changeset.
Run this command to commit all local changes:
```bash
cm status | cm ci . -c "my first commit"
```
### Undoing local changes
Just in case you don't want or can't commit your local changes, there is an undo command.
This will undo all local changes:
```bash
cm status | cm undo .
```
### Changing, moving or deleting files
All these actions are done on the file level. You can run `cm status` to see your actions beeing tracked by plastic.
Use the commit method described above to commit your changes.
**Test hint:** All these changes should be counted by the designated property (`Modified`, `Moved`, `Deleted`)
of the `plastic` segment.
### Branching
Above the basics of handling the Plastic SCM client are described.
But you would want to dive deeper and use branches or labels and merge them.
#### Create a new branch
To create a new branch based on the latest changeset on branch `/main` call
```bash
cm br /main/new-branch
```
Hint: To list all branches use
```bash
cm find branches
```
#### Set a label to the current changeset
Your workspace will always reflect one specific changeset (see `cm status`). You can set a label on that changeset for
fast navigation or documentation purposes
```bash
cm label mk "BL0001"
```
Hint: To list all labels use
```bash
cm find labels
```
#### Switch your local workspace to a branch
To switch to a branch use
```bash
cm switch /main/new-branch
cm status
```
**Test Hint:** the branch name should be reflected in the `Selector` property of the `plastic` segment
#### Switch to a changeset
Each commit gets a unique changeset number. You can switch to these via
```bash
cm switch cs:1
```
**Test Hint:** the changeset should be reflected in the `Selector` property of the `plastic` segment
#### Switch to a label
You can also switch to a label via
```bash
cm switch BL00001
```
**Test Hint:** the label should be reflected in the `Selector` property of the `plastic` segment
#### Merge a branch
To merge a branch you have to switch to the *destination* branch of the merge. After that you can merge another branch via
```bash
cm switch /main
cm merge /main/new-branch --merge
cm status
```
Hint: This will only prepare the merge locally. You will have to commit the changes to complete the merge!
**Test Hint:** A pending merge should be reflected in the `MergePending` property of the `plastic` segment
#### Cherry-pick merge
While the merge above will merge all changes from a branch (and his parents), there is a cherry-pick merge,
which will merge only the changes of one single changeset
```bach
cm merge cs:8 --merge --cherrypicking
```
Hint: This will only prepare the merge locally. You will have to commit the changes to complete the merge!
**Test Hint:** A pending cherry-pick merge should be reflected in the `MergePending` property of the `plastic` segment
#### Merge conflicts
There are multiple causes for conflicts while merging
##### Evil Twin
This happens when a merge is performed where two files with the same name were added on both the source and destination branch.
```bash
cm br mk /main/sub-branch
cm switch /main/sub-branch
echo "1" > twin.txt
cm add twin.txt
cm ci twin.txt
cm switch /main
echo "2" > twin.txt
cm add twin.txt
cm ci twin.txt
cm merge /main/sub-branch --merge
```
Hint: this will prompt you to directly resolve the conflict
##### Changed on both sides
This happens when a merge is performed where a file was changed on both sides: source and destination
```bash
cm switch /main
echo "base" > file.txt
cm add file.txt
cm ci file.txt
cm br mk /main/test
echo "on main" > file.txt
cm ci file.txt
cm switch /main/test
echo "on test" > file.txt
cm ci file.txt
cm switch /main
cm merge /main/test --merge
```
Hint: this will try to open `gtkmergetool` which will fail inside the dev-container!
##### Changed vs. deleted file
This happens when a merge is performed where a file was modified on one side and deleted on the other side of the merge
```bash
cm switch /main
echo "base" > deleteme.txt
cm add deleteme.txt
cm ci deleteme.txt
cm br mk /main/del
rm deleteme.txt
cm ci --all
cm switch /main/del
echo "on del" > deleteme.txt
cm ci deleteme.txt
cm switch /main
cm merge /main/del --merge
```
Hint: This will prompt you to directly resolve the merge conflict
[plastic]: https://www.plasticscm.com/
[setup-instructions]: https://www.plasticscm.com/documentation/administration/plastic-scm-version-control-administrator-guide#Chapter3:PlasticSCMinstallation
[server-config]: https://www.plasticscm.com/documentation/administration/plastic-scm-version-control-administrator-guide#Serverconfiguration
[contributing]: https://github.com/JanDeDobbeleer/oh-my-posh/blob/main/CONTRIBUTING.md
[devcontainer]: https://github.com/JanDeDobbeleer/oh-my-posh/blob/main/CONTRIBUTING.md#codespaces--devcontainer-development-environment