Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Initial release #1

Open
wants to merge 29 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
f8768f1
Adding dynamic fetching for .NET library dependencies.
CameronSWilliamson Jul 15, 2024
cc5cd34
Adding New-YTSession function that creates a session object.
CameronSWilliamson Jul 15, 2024
508ae23
Adding automated setup for YouTrack
CameronSWilliamson Jul 18, 2024
182bf56
Moving automation to python to make it easier on appveyor
CameronSWilliamson Jul 19, 2024
7095cbb
Providing zipped YouTrack instance for testing
CameronSWilliamson Jul 25, 2024
ae989f8
Ending Youtrack process on build servers
CameronSWilliamson Jul 26, 2024
90436aa
Adding support for Unix operating systems
CameronSWilliamson Jul 26, 2024
1ffe7c3
Removing all dll dependencies
CameronSWilliamson Jul 26, 2024
6318490
Updating init to use ytconfig.zip and download youtrack from the website
CameronSWilliamson Jul 26, 2024
ef6f213
Adding Invoke-YTRestMethod function
CameronSWilliamson Jul 26, 2024
a7d7e6d
Adding Get-YTIssue function
CameronSWilliamson Jul 29, 2024
b3e3aa1
Adding get project and new project functions
CameronSWilliamson Aug 1, 2024
0884e6c
Adding New-YTIssue function and unittests
CameronSWilliamson Aug 2, 2024
46dcf80
Fixing failing tests
CameronSWilliamson Aug 5, 2024
1866c5f
Ready for first release
CameronSWilliamson Aug 5, 2024
4a15b62
Adding Remove-YTProject function
CameronSWilliamson Jan 6, 2025
aea8cb2
Removing all projects before each test suite
CameronSWilliamson Jan 6, 2025
97110c4
Adding test that makes a real request
CameronSWilliamson Jan 6, 2025
ef243a3
Adding support for error descriptions when invoking youtrack rest met…
CameronSWilliamson Jan 7, 2025
c5ad7a8
Adding Remove-AllProjects helper function and updating documentation …
CameronSWilliamson Jan 7, 2025
5b5a418
Adding function to get IDs for custom fields and to get the state of …
CameronSWilliamson Jan 9, 2025
4cd3f22
Adding support for getting an issue's custom fields.
CameronSWilliamson Jan 14, 2025
0f1c7c3
Check in YouTrack config as loose files instead of a zip.
KhoiKy Jan 24, 2025
4532698
Rename test helper function to Clear-Project.
KhoiKy Jan 24, 2025
b43813d
Use EscapeDataString instead of EscapeUriString.
KhoiKy Jan 24, 2025
b25e25f
Parameter name should be singular.
KhoiKy Jan 24, 2025
f7ceb28
Update module's help.txt
KhoiKy Jan 24, 2025
b69a854
Update tests so that they don't mock invoking of rest methods.
KhoiKy Jan 24, 2025
3f058e7
Improve documentation on functions.
KhoiKy Jan 25, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,6 @@
/YouTrackAutomation/LICENSE.txt
/YouTrackAutomation/NOTICE.txt
/YouTrackAutomation/README.md
/YouTrackAutomation/Bin
/packages
/youtrack-2024.2.37269
16 changes: 15 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Overview

The "YouTrackAutomation" module...
The "YouTrackAutomation" module is a PowerShell module built to interface with the YouTrack REST API.

# System Requirements

Expand All @@ -24,3 +24,17 @@ Import-Module -Name '.\YouTrackAutomation'
```

# Commands

## Creating a new session

All commands require a `session` object in order to call them. Create a new session object using the `New-YTSession`
command.

## Interacting With API

* `Get-YTIssue`
* `Get-YTProject`
* `Invoke-YTRestMethod`
* `New-YTIssue`
* `New-YTProject`
* `New-YTSession`
36 changes: 0 additions & 36 deletions TODO.md

This file was deleted.

66 changes: 66 additions & 0 deletions Tests/Get-YTIssue.Tests.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
Set-StrictMode -Version 'Latest'

BeforeAll {
Set-StrictMode -Version 'Latest'

& (Join-Path -Path $PSScriptRoot -ChildPath 'Initialize-Test.ps1' -Resolve)

function WhenGettingIssue
{
[CmdletBinding()]
param(
[Parameter(Mandatory)]
[String] $IssueId,
[String] $AdditionalField
)

$script:result = Get-YTIssue -Session $session @PSBoundParameters
}

function ThenIssueHasValue
{
[CmdletBinding()]
param(
[String] $Field,
[String] $Value
)

$script:result.$Field | Should -Be $Value
}

function ThenIssueHasField
{
[CmdletBinding()]
param(
[String] $Field
)

$script:result.$Field | Should -Not -BeNullOrEmpty
}
}

Describe 'Get-YTIssue' {
BeforeEach {
$script:session = New-YTSession -Url $apiUrl -ApiToken $apiToken
}

It 'should return an issue using the ''jira id''' {
WhenGettingIssue -IssueId '3-4'
ThenIssueHasValue -Field 'idReadable' -Value 'DEMO-5'
ThenIssueHasValue -Field 'id' -Value '3-4'
ThenIssueHasValue -Field 'summary' -Value 'First steps for project administrators'
}

It 'should return an issue using the ''issue key''' {
WhenGettingIssue -IssueId 'DEMO-1'
ThenIssueHasValue -Field 'id' -Value '3-0'
ThenIssueHasValue -Field 'idReadable' -Value 'DEMO-1'
ThenIssueHasValue -Field 'summary' -Value 'Launch YouTrack'
}

It 'should support additional fields' {
$additionalFields = 'comments(id,author(name),text,created,updated)'
WhenGettingIssue -IssueId 'DEMO-1' -AdditionalField $additionalFields
ThenIssueHasField -Field 'comments'
}
}
96 changes: 96 additions & 0 deletions Tests/Get-YTProject.Tests.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
Set-StrictMode -Version 'Latest'

BeforeAll {
Set-StrictMode -Version 'Latest'

& (Join-Path -Path $PSScriptRoot -ChildPath 'Initialize-Test.ps1' -Resolve)

Clear-Project -Wait

function GivenProject
{
[CmdletBinding()]
param(
[String] $ShortName = 'GYTP1',
[String] $Name = 'Get-YTProject Test Project',
[String] $Leader = 'admin'
)

$script:projectShortName = $ShortName
New-YTProject -Session $script:session -ShortName $ShortName -Name $Name -Leader $Leader -Description 'This is a test project.'
}

function WhenGettingProject
{
[CmdletBinding()]
param(
[String] $ShortName,
[String] $AdditionalField
)

$script:result = Get-YTProject -Session $script:session @PSBoundParameters
}

function ThenReturns
{
[CmdletBinding()]
param(
[int] $Count,
[String[]] $ProjectWithShortName,
[String] $ProjectWithField
)

if ($Count)
{
$script:result | Should -Not -BeNullOrEmpty
if (Get-Member -Name Length -InputObject $script:result -ErrorAction SilentlyContinue)
{
$script:result.Length | Should -Be $Count
}
$idCount =
$script:result |
ForEach-Object { $_.id } |
Select-Object -Unique |
Measure-Object |
Select-Object -ExpandProperty Count
$script:result | Should -HaveCount $idCount
}

if ($ProjectWithField)
{
$script:result.$ProjectWithField | Should -Not -BeNullOrEmpty
}

if ($ProjectWithShortName)
{
$script:result |
ForEach-Object { $_.shortName} |
Where-Object { $_ -in $ProjectWithShortName } |
Should -Not -BeNullOrEmpty
}
}
}

Describe 'Get-YTProject' {
BeforeEach {
$script:session = New-YTSession -Url $apiUrl -ApiToken $apiToken
$script:result = $null
}

It 'returns one project' {
GivenProject -ShortName 'GYTP1' -Name 'Get-YTProject Test Project' -Leader 'admin'
WhenGettingProject -ShortName 'GYTP1'
ThenReturns -Count 1 -ProjectWithShortName 'GYTP1'
}

It 'return all projects' {
GivenProject -ShortName 'GYTP2' -Name 'Get-YTProject Test Project' -Leader 'admin'
WhenGettingProject
ThenReturns -Count 2 -ProjectWithShortName 'GYTP1', 'GYTP2'
}

It 'should support additional fields' {
WhenGettingProject -ShortName 'GYTP1' -AdditionalField 'description'
ThenReturns -Count 2 -ProjectWithField 'description'
}
}
48 changes: 48 additions & 0 deletions Tests/Invoke-YTRestMethod.Tests.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
Set-StrictMode -Version 'Latest'

BeforeAll {
Set-StrictMode -Version 'Latest'

& (Join-Path -Path $PSScriptRoot -ChildPath 'Initialize-Test.ps1' -Resolve)
}

Describe 'Invoke-YTRestMethod' {
splatteredbits marked this conversation as resolved.
Show resolved Hide resolved
BeforeEach {
$script:session = New-YTSession -Url $apiUrl -ApiToken $apiToken
}

It 'should always make GET requests' {
splatteredbits marked this conversation as resolved.
Show resolved Hide resolved
$res = Invoke-YTRestMethod -Session $script:session -Name 'users/me' -Method Get
$res.id | Should -Not -BeNullOrEmpty
$res.'$type' | Should -Be 'Me'
$res = Invoke-YTRestMethod -Session $script:session -Name 'users/me' -Method Get -WhatIf
$res.id | Should -Not -BeNullOrEmpty
$res.'$type' | Should -Be 'Me'
}

It 'should not make POST requests with WhatIf' {
Clear-Project -Wait
New-YTProject -Session $script:session -Name 'Invoke-YTRestMethod' -ShortName 'IYTRM' -Leader 'admin'
$project = Invoke-YTRestMethod -Session $script:session -Name 'admin/projects?fields=id,name,shortName'
$issue = New-YTIssue -Session $script:session -Project $project -Summary 'Test Ticket' -Description 'This is a test ticket.'

# Should update issue summary
$res = Invoke-YTRestMethod -Session $script:session -Name "issues/$($issue.id)" -Body @{summary = "New Title"} -Method Post
$res | Should -Not -BeNullOrEmpty
$res.id | Should -Be $issue.id
$issue = Get-YTIssue -Session $script:session -IssueId $issue.id
$issue.summary | Should -Be "New Title"

# Should not update issue summary
Invoke-YTRestMethod -Session $script:session -Name "issues/$($issue.id)" -Body @{summary = "Another Title"} -Method Post -WhatIf
$issue = Get-YTIssue -Session $script:session -IssueId $issue.id
$issue.summary | Should -Be "New Title"
}

It 'should get projects' {
Clear-Project -Wait
New-YTProject -Session $script:session -Name 'Invoke-YTRestMethod' -ShortName 'IYTRM' -Leader 'admin'
$project = Invoke-YTRestMethod -Session $script:session -Name 'admin/projects?fields=id,name,shortName'
$project | Should -HaveCount 1
}
}
80 changes: 80 additions & 0 deletions Tests/New-YTIssue.Tests.ps1
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
Set-StrictMode -Version 'Latest'

BeforeAll {
Set-StrictMode -Version 'Latest'
& (Join-Path -Path $PSScriptRoot -ChildPath 'Initialize-Test.ps1' -Resolve)

$script:session = New-YTSession -Url $apiUrl -ApiToken $apiToken
Clear-Project -Wait

New-YTProject -Session $script:session -Leader 'admin' -Name 'New-YTIssue' -ShortName 'NYTI' -ErrorAction Stop | Out-Null

function WhenCreatingIssue
{
param(
[String] $WithSummary,
[String] $WithDescription,
[String] $InProject
)

$splat = @{}

if ($WithSummary)
{
$splat['Summary'] = $WithSummary
}

if ($WithDescription)
{
$splat['Description'] = $WithDescription
}

if ($InProject)
{
$splat['Project'] = $InProject
}


$script:result = New-YTIssue -Session $script:session @splat
}

function ThenIssue
{
[CmdletBinding()]
param(
[String] $Summary,
[String] $Description,
[String] $Project
)

$script:result.idReadable | Should -Not -BeNullOrEmpty
$issue = Get-YTIssue -Session $script:session -IssueId $script:result.idReadable

$issue.summary | Should -Be $Summary
$issue.project.shortName | Should -Be $Project
$issue.description | Should -Be $Description
$issue.reporter.name | Should -Be 'admin'
}
}

Describe 'New-YTIssue' {
BeforeEach {
$script:summary = $null
$script:description = $null
$script:project = $null
}

It 'should create a new issue' {
WhenCreatingIssue -WithSummary 'First YTAutomation Issue' -WithDescription 'This is the first issue created by the YouTrackAutomation module.' -InProject 'NYTI'
ThenIssue -Summary 'First YTAutomation Issue' -Description 'This is the first issue created by the YouTrackAutomation module.' -Project 'NYTI'
}

It 'should allow issues with the same summary and description' {
WhenCreatingIssue -WithSummary 'same summary' -WithDescription 'same description' -InProject 'NYTI'
ThenIssue -Summary 'same summary' -Description 'same description' -Project 'NYTI'
$initialIssueId = $script:result.idReadable
WhenCreatingIssue -WithSummary 'same summary' -WithDescription 'same description' -InProject 'NYTI'
ThenIssue -Summary 'same summary' -Description 'same description' -Project 'NYTI'
$script:result.idReadable | Should -Not -Be $initialIssueId
}
}
Loading