Что нового в PowerShell Core 6.2 Preview4


PowerShell Core 6.2 Preview4 это последняя предварительная версия перед выпуском релиза 6.2. (Ещё будет RC версия, сам релиз запланирован на март). Так что если вы обнаружили какие-то проблемы, то спешите сообщить в https://github.com/PowerShell/PowerShell

Последние важные изменения в репозитории:

  1. Завершен переход на Azure DevOps CIs. Проведена зачистка скриптов от старых CIs.
  2. За новогодние праздники вычищено около 30000 ошибок форматирования кода, которые рапортовал CodeFactor сервис. Осталось ещё более 70000. Сейчас публиковать изменения кода стало намного легче: практически нет замечаний по форматированию. В планах улучшить настройки CodeFactor, т.к. не все его сообщения должны быть исправлены.
  3. Документация практически вся удалена и перенесена в соответствующий репозиторий https://github.com/MicrosoftDocs/PowerShell-Docs

 

Что нового в Core 6.2 Preview4:

  1. Внесено ряд исправлений в web-командлеты (#8694, #8679)
  2. Sort-Object получил ключ Stable (#7862)
  3. Hashtable теперь case-insensitive для всех Cultures (#8566)
  4. Добавлен параметер RepeatHeader в командлет Format-Table (#8481)
  5. Добавлена поддержка enum и char типов в Format-Hex (#8191)
  6. Добавлена поддержка подсказок в случае ввода ошибочного имени команды (тестируйте и пишите отзывы) (#8458)

И ещё много чего. Полный список изменений https://github.com/PowerShell/PowerShell/releases/tag/v6.2.0-preview.4

Реклама

Хостинг PowerShell


При создании приложений использующих PowerShell (хостинг PowerShell) важно понимать следующее.

  1. Для совместимости с Windows PowerShell используется PowerShell.5.ReferenceAssemblies
  2. Для совместимости с PowerShell Core используется PowerShell.SDK
  3. Для создания модулей, которые работают в обеих версиях, нужно использовать PowerShellStandard.Library

Полезные ссылки:

  1. https://docs.microsoft.com/en-us/powershell/scripting/learn/writing-portable-modules?view=powershell-6
  2. https://github.com/MicrosoftDocs/PowerShell-Docs

PowerShell Core 6.2.0 Preview3


Традиционно краткий обзор того, что появилось и изменилось:

  • Прошла очередная волна зачистки кода от старых рудиментов
  •  Отладчик теперь не будет задавать вам много ненужных вопросов #8195
  •  Уменьшина вероятность проблем при множественном доступе к powershell.config.json #8249
  •  Появился новый командлет Join-String #7660
  • Get-PSHostProcessInfo и Enter-PSHostProcessтеперь работают на Unix #8232
  •  Улучшено время запуска #8341 #8396. Теперь почти как Windows PowerShell, немного медленнее. Сейчас вообще стали больше смотреть на производительность. Надеюсь, это будет постоянным процессом
  •  Добавлена поддержка Linux ARM64 #8016

Сейчас, пока наблюдается праздничное затишье, идёт активная работа по улучшению форматирования на основе отчётов CodeFactor (StyleCop). Код PowerShell создавался многие годы, разными людьми, менялись предпочтения по стилю форматирования. В результате сейчас мы имеем около 100 тысяч замечаний в CodeFactor. Некоторые правила будут выключены как бесполезные. Часть замечаний уже исправлены (>12 тысяч). За эти дни мы должны ещё хорошо продвинуться в этом направлении. Надеюсь, что после этого останется менее половины замечаний в CodeFactor. Всё это значительно улучшит читабельность и документированность кода и облегчит разработчикам создание изменений (PR).

PowerShell Core 6.1.1


В PowerShell Core 6 были обнаружены проблемы безопасности. В Windows PowerShell тоже, и исправления уже доступны в текущих ежемесячных обновлениях.

Что касается PowerShell Core 6, то его рекомендуется обновить до версии 6.1.1.

Подробности:

https://github.com/PowerShell/PowerShell/issues/8254

https://github.com/PowerShell/PowerShell/issues/8251

О чём это говорит? Хочется думать, что PowerShell Core стал достаточно популярным :-) Хотя по факту одна проблема приехала из Microsoft.PowerShell.Archive, а вторая исторически из Windows PowerShell. Пока инцидентов с новым кодом, созданным в рамках проекта с открытыми кодами, не зафиксировано: предыдущие обновления безопасности происходили из .Net Core.

Кратко о PowerShell Core 6.2.0 Preview1


Загрузка на GitHub.

Команда MSFT сосредоточена на автоматизации. Практически завершён процесс перехода с CI Appveyor и CI Travis на платформу visualstudio.com (Azure DevOps). Сам процесс автоматизации выпусков новых версий по всей видимости приведёт не только к снижению трудозатрат, но и большей интеграции в эко систему как Windows, так и основных Linux дистрибутивов.

Что появилось нового в Preview1?

  • #7813 и #7901 — добавлена поддержка типов byte, ushort, uint, ulong и short в виде литералов и акселераторов.
  • #7732 — для параметра Encoding добавлена поддержка IntelliSense (автозавершение).
  • #7206 — добавлена поддержка cd +
  • Как побочный эффект заработало IntelliSense для $error[0] . Отсутствие этого всегда раздражало.

Остальное можно найти в ChangeLog https://github.com/PowerShell/PowerShell/releases/tag/v6.2.0-preview.1 Как всегда там множество изменений маленьких и больших.

 

 

PowerShell Core 6.1 выпущен!


Официальный анонс https://blogs.msdn.microsoft.com/powershell/2018/09/13/announcing-powershell-core-6-1/

Release Notes и загрузка https://github.com/PowerShell/PowerShell/releases

Также доступен в Snap. Постепенно расширяется число репозиториев, через которые можно установить PowerShell Core.

PowerShell Core 6.1 работает на базе .Net Core 2.1.

Самое приятное, что были найдены и исправлены некоторые проблемы производительности. Целый ряд командлетов теперь потребляет меньше памяти и работает существенно быстрее, даже лучше, чем Windows PowerShell.

Разработчики Microsoft проделали огромную работу по обеспечению совместимости с PowerShell модулями поставляемым с Windows 10 и Window Server 2019. Да, это доступно только для новых версий. Для старых надо использовать механизм проксирования реализованный в модуле WindowsConpatibility.

Больше подробностей об изменениях в статье https://isazonov.wordpress.com/2018/08/28/powershell-core-6-1-0-rc1/

PowerShell Core 6.1.0 RC1


Приближается дата выпуска PowerShell Core 6.1.0. Предварительная дата — 13 сентября 2018 года.
А пока выпушена версия RC1 — самое время попробовать установить и сообщить о проблемах на https://github.com/PowerShell/PowerShell/
Ничего нового в RTM по сравнению с RC1 не добавится — как что стартуйте!

Загрузка https://github.com/PowerShell/PowerShell/releases/tag/v6.1.0-rc.1

1. Вы можете устанавливать предварительные версии одновременно с релизами. Это разные пакеты и они ставятся независимо. На Windows даже иконка предварительной версии будет иной. Предварительные версии имеют суффикс «-preview».
2. Добавлены пакеты в формате Snap.
3. Используется .Net Core 2.1.2 (2.1.302)
Были обнаружены некоторые проблемы производительности. Кое-что уже исправлено.
1. Одна проблема связана с OrderedDictionary класс. https://github.com/dotnet/corefx/issues/31972
Суть в том, что невозможно проверить состояние любого свойства, например, что объект пуст и не имеет добавленных элементов, без выделения памяти под внутренние структуры. PowerShell Core использует OrderedDictionary в базовом классе PSObject В результате PowerShell Core потреблял огромное количество ненужной памяти. Исправлено в [#7435](https://github.com/PowerShell/PowerShell/pull/7435).
2. Еще одна проблема с потреблением памяти и производительностью исправлена в [#7413](https://github.com/PowerShell/PowerShell/pull/7413)
В результате командлет Import-Csv стал работать быстрее до 10 раз (!) и потреблять меньше памяти.
3. Командлеты Convertfrom-Json и Invoke-RestMethod стали до 7 раз быстрее делать преобразование Json в PSObject
[#7482](https://github.com/PowerShell/PowerShell/pull/7482)
4. Значительно ускорена работа Group-Object cmdlet [#7410](https://github.com/PowerShell/PowerShell/pull/7410)
5. Было сделано еще несколько улучшений произвидительности в движке. Работа в этом направлении продолжается. Смотрите [#7112](https://github.com/PowerShell/PowerShell/issues/7112)

Что еще нового?
1. Появятся командлеты для рендеринга Markdown [6926](https://github.com/PowerShell/PowerShell/pull/6926)
Это направление работы связано с добавлением прямой поддержки файлов помощи в формате Markdown. Сейчас документация готовится в формате Markdown (https://github.com/PowerShell/PowerShell-Docs), но конвертится в MAML, чтобы мы могли использовать её в Get-Help.
2. Был удален VisualBasic из Add-Type [#7284](https://github.com/PowerShell/PowerShell/pull/7284)
Гланая мотивация — уменьшение размера дистрибутива на 5 Мб. С другой стороны мы имеем запрос на добавление поддержки F#. Посмотрим что скажут пользователи, т.е. мы с вами.
3. Была добавлена поддержка экспериментальных фичей [#7242](https://github.com/PowerShell/PowerShell/pull/7242)
Теперь в предварительных версиях возможно появление опциональных/несовместимых фичей, которые могут быть включены/выключены в конфиге для выборочного тестирования.
4. Добавлена поддержка истории в Set-Location, «cd -» — вывод предыдущей команды. [#5051](https://github.com/PowerShell/PowerShell/pull/5051)
5. Вернули акселераторы ADSI и WMI [#7085](https://github.com/PowerShell/PowerShell/pull/7085)
Собственно благодаря добавлению Windows Compatibility Pack 2.0.0 [#6958](https://github.com/PowerShell/PowerShell/pull/6958) — он оказался нужен в ядре для поддержки совместимости Windows PowerShell модулей.
6. Invoke-Item теперь работает на всех платформах [7198](https://github.com/PowerShell/PowerShell/pull/7198)
Т.е. теперь на Linux и MacOs должно работать Invoke-Item(«https://www.microsoft.com/»)
7. Теперь работает Basic Auth over HTTPS [#6890](https://github.com/PowerShell/PowerShell/pull/6890)
8. Добавлены новые командлеты для распараллеливания работы — ThreadJob модуль [#7169](https://github.com/PowerShell/PowerShell/pull/7169)
Принципиально ничего нового: используется стандартные возможности ядра, которые достаточно медленные, но стало очень удобно — попробуйте!
9. Measure-Command поддерживает скрипт-блоки [#6934](https://github.com/PowerShell/PowerShell/pull/6934)
Пример, @{prop = 3} | measure-object {$_.prop}

Там ещё много чего нового — смотрите Release Notes.

Как обычно я продолжил чистку кода. Удалено много p/invoke вызовов в FileSystem провайдере. Выполнено переформатирование Utility и Management модулей. Усправлена куча проблем в стилях и формтировании, которые репортятся в CodeFactor (StyleCop). Это работа идет медленно, так как она непроизводительная и не создает нового. Хотя приводит код в порядок и облегчает работу другим. Очень надеюсь, что удастся довести эту работу до конца в ближайшие месяцы.

Осталось напомнить, что идет процесс портирования модулей Windows. Их уже можно потестировать в последних сборках Windows 10 Preview. Читайте https://blogs.msdn.microsoft.com/powershell/2018/07/31/increased-windows-modules-coverage-with-powershell-core-6-1/ , а также попробуйте [Windows PowerShell Compatibility module](https://github.com/PowerShell/WindowsCompatibility)
Если какой-то Windows модуль не работает в PowerShell Core, то сообщить об этом можно сюда [PowerShellModuleCoverage](https://github.com/PowerShell/PowerShellModuleCoverage).

Также пишите в [основной репозиторий](https://github.com/PowerShell/PowerShell), если вы обнаружили проблемы в PowerShell Core (ошибки или плохая производительность) или имеете предложения по развитию.