qwiq - Qwiq.Core 11.0.0-beta0055
Provides Quick Work Item Queries to Team Foundation Server and Visual Studio Online
PM> Install-Package Qwiq.Core -Version 11.0.0-beta0055 -Source https://www.myget.org/F/qwiq/api/v3/index.json
> nuget.exe install Qwiq.Core -Version 11.0.0-beta0055 -Source https://www.myget.org/F/qwiq/api/v3/index.json
> dotnet add package Qwiq.Core --version 11.0.0-beta0055 --source https://www.myget.org/F/qwiq/api/v3/index.json
source https://www.myget.org/F/qwiq/api/v3/index.json
nuget Qwiq.Core ~> 11.0.0-beta0055
Copy to clipboard
> choco install Qwiq.Core --version 11.0.0-beta0055 --source https://www.myget.org/F/qwiq/api/v2
Import-Module PowerShellGet
Register-PSRepository -Name "qwiq" -SourceLocation "https://www.myget.org/F/qwiq/api/v2"
Install-Module -Name "Qwiq.Core" -RequiredVersion "11.0.0-beta0055" -Repository "qwiq" -AllowPreRelease
Copy to clipboard
Browse the sources in this package using Visual Studio or WinDbg by configuring the following legacy symbol server URL: https://www.myget.org/F/qwiq/symbols/
QWIQ
QWIQ is a Quick Work Item Query library for Team Foundation Server / Visual Studio Online. If you do a lot of reading or writing of work items, this package is for you!
What can it be used for?
Querying Team Foundation Server, of course! Instead of directly using the TFS Client OM, you could use QWIQ! It it made of packages designed to make working with Tfs/Vso a pleasure. Qwiq.Core is the no-frills base package, exposinng the raw types needed to read and write work items. Qwiq.Identity adds methods to simplify converting between your preferred method of identity (display names, user names) and TFS's identity classes. Qwiq.Linq provides a Linq query provider to be able to write Linq to query tfs. Qwiq.Mapper enables converting from IWorkItem, the raw Qwiq.Core type, to your own classes to enable strongly typed access to your WorkItems. Qwiq.Relatives extends Qwiq.Linq to enable slightly more complicated queries allowing for basic queries of related workitems. Qwiq.Mocks provides default implementations for commonly mocked classes within Qwiq, and should allow for getting up and unit testing quickly. Why use this over the Client OM? Glad you asked!
1. Easier to consume
Let's be honest, the TFS libraries are a pain to use. There are a lot of them, several are dynamically loaded, and a few are native. While we can't avoid it, you can! Just install the Qwiq.Core package and everything will be in your \bin folder when you need it.
2. Easier to test
Qwiq makes testing your apps a breeze. Everything has an interface. Everything uses factories (or factory methods) instead of constructors. Just mock what you need for your tests and go. No more messy, temperamental fakes, or adapters cluttering your code.
3. Easier to understand
How often do you update a work item? How often do you create a new security group? We stripped out the rarely used stuff to make interfaces cleaner and the relationships between types simpler. Missing something you can't live without? Send us a pull request!
How to install it
Add our MyGet feed to your NuGet clients:
- v3 (VS 2015+ / NuGet 3.x):
https://www.myget.org/F/qwiq/api/v3/index.json
- v2 (VS 2013 / NuGet 2.x):
https://www.myget.org/F/qwiq/api/v2
Once the feed is configured, install via the nuget UI or via the nuget package manager console
Install Core
From the NuGet package manager console
PM> Install-Package Microsoft.Qwiq.Core
Or via the UI Microsoft.Qwiq.Core,
Install Client
We now have two clients: one for SOAP, and one for REST
From the NuGet package manager console
PM> Install-Package Microsoft.Qwiq.Client.Soap
Or via the UI Microsoft.Qwiq.Client.Soap,
Basic Usage
using Microsoft.Qwiq;
using Microsoft.Qwiq.Credentials;
using Microsoft.VisualStudio.Services.Client;
...
// We support
// - OAuth2
// - Personal Access Token (PAT)
// - Username and password (BASIC)
// - Windows credentials (NTLM or Federated with Azure Active Directory)
// - Anonymous
// Use the full URI, including the collection. Example: https://QWIQ.VisualStudio.com/DefaultCollection
var uri = new Uri("[Tfs Tenant Uri]");
var options = new AuthenticationOptions(uri, AuthenticationType.Windows);
var store = WorkItemStoreFactory
.Default
.Create(options);
// Execute WIQL
var items = store.Query(@"
SELECT [System.Id]
FROM WorkItems
WHERE [System.WorkItemType] = 'Bug' AND State = 'Active'");
[Reflection.Assembly]::LoadFrom("E:\Path\To\Microsoft.Qwiq.Core.dll")
# Can use SOAP or REST clients here
[Reflection.Assembly]::LoadFrom("E:\Path\To\Microsoft.Qwiq.Client.Soap.dll")
$uri = [Uri]"[Tfs Tenant Uri]"
$options = New-Object Microsoft.Qwiq.Credentials.AuthenticationOptions $uri,Windows
$store = [Microsoft.Qwiq.Client.Soap.WorkItemStoreFactory]::Default.Create($options)
$items = $store.Query(@"
SELECT [System.Id]
FROM WorkItems
WHERE [System.WorkItemType] = 'Bug' AND State = 'Active'", $false)
Contributing
Getting started with Git and GitHub
- Setting up Git for Windows and connecting to GitHub
- Forking a GitHub repository
- The simple guide to GIT guide
- Open an issue if you encounter a bug or have a suggestion for improvements/features
Once you're familiar with Git and GitHub, clone the repository and start contributing!
-
Any 0.0
- Castle.Core (>= 4.0.0)
- Microsoft.AspNet.WebApi.Client (>= 5.2.3)
- Microsoft.IdentityModel.Clients.ActiveDirectory (>= 3.13.9)
- Microsoft.VisualStudio.Services.InteractiveClient (>= 15.112.1)
- Newtonsoft.Json (>= 10.0.2)
- System.IdentityModel.Tokens.Jwt (>= 4.0.4.403061554)
- .NETFramework 4.6: 4.6.0.0
Assembly | Assembly hash | Match |
---|---|---|
/lib/net46/qwiq.core.dll | 1dbc00a2b495406399b922c5b98cb5af1 |
OwnersRichard Murillo qwiq |
AuthorsLeCantaloop |
Project URLhttps://github.com/LeCantaloop/Qwiq |
LicenseMIT |
TagsMicrosoft Team Foundation Server TFS VSO Visual Studio Online VisualStudio Agile WIT Work Item Tracking Object Model VSTS TeamFoundation TFSOM |
Info10 total downloads |
2 downloads for version 11.0.0-beta0055 |
Download (57.08 KB) |
Download legacy symbols (243.76 KB) |
Found on the current feed only |
Package history
Version | Size | Last updated | Downloads | Mirrored? | |||
---|---|---|---|---|---|---|---|
11.0.0-beta0055 | 57.08 KB | Wed, 06 Mar 2019 01:16:55 GMT | 2 | ||||
11.0.0-beta0053 | 57.04 KB | Fri, 26 Oct 2018 21:54:14 GMT | 2 | ||||
10.0.1 | 54.83 KB | Mon, 12 Feb 2018 22:38:57 GMT | 3 | ||||
10.0.0 | 54.67 KB | Mon, 12 Feb 2018 18:49:35 GMT | 3 |