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

Upcoming Release: FluidFramework v2.20.0 #22101

Open
tylerbutler opened this issue Aug 1, 2024 · 0 comments
Open

Upcoming Release: FluidFramework v2.20.0 #22101

tylerbutler opened this issue Aug 1, 2024 · 0 comments

Comments

@tylerbutler
Copy link
Member

tylerbutler commented Aug 1, 2024

This issue is automatically updated with a preview of the release notes for the upcoming Fluid Framework release.

To generate release notes locally to commit to the RELEASE_NOTES folder in the repo, run the following command:

pnpm flub generate releaseNotes -g client -t minor --outFile RELEASE_NOTES/2.20.0.md

To generate the release notes to paste into the GitHub Release, run the following command:

pnpm flub generate releaseNotes -g client -t minor --headingLinks --excludeH1 --outFile temporary-file.md

This should happen automatically as part of the release process, but if you need to generate the release notes manually, you can use the above command.


Fluid Framework v2.20.0

Contents

🐛 Bug Fixes

⚠️ Deprecations

Deprecation Notice: Events Interfaces Migrated to @fluidframework/core-interfaces (#23313)

The following interfaces and types are now deprecated in @fluidframework/tree. It is recommended to import them from either @fluidframework/core-interfaces or fluid-framework.

  • Listeners
  • IsListener
  • Listenable
  • Off

These deprecated interfaces are planned for removal from @fluidframework/tree package in Fluid Framework 3.0 release.

Change details

Commit: 69a755e

Affected packages:

  • @fluidframework/tree

⬆️ Table of contents

Legacy API Changes

MockLogger has been removed from the alpha+legacy API surface (#23473)

The MockLogger class previously exposed in the alpha+legacy API surface of @fluidframework/telemetry-utils has been removed. No replacement is provided, as this class was only intended for use in testing scenarios, and should be trivial to re-implement in any codebase that still uses it.

Change details

Commit: 237f042

Affected packages:

  • @fluidframework/telemetry-utils

⬆️ Table of contents

Remove deprecated Merge-Tree and SharedString ISegment members (#23448)

The current ISegment interface over-exposes a number of properties which do not have an external use case, and any external usage could result in damage to the underlying merge-tree including data corruption. In Fluid Framework release 2.12.0 these properties and associated types were deprecated.

The only use case that will continue to be supported is determining if a segment is removed. For this purpose we've added the free function segmentIsRemoved(segment: ISegment): boolean.

For example, checking if a segment is not removed would change as follows:

- if(segment.removedSeq === undefined){
+ if(!segmentIsRemoved(segment)){

The following properties are removed from ISegment and its implementations:

  • clientId
  • index
  • localMovedSeq
  • localRefs
  • localRemovedSeq
  • localSeq
  • movedClientsIds
  • movedSeq
  • movedSeqs
  • ordinal
  • removedClientIds
  • removedSeq
  • seq
  • wasMovedOnInsert

Additionally, the following types are also removed:

  • IMergeNodeCommon
  • IMoveInfo
  • IRemovalInfo
  • LocalReferenceCollection

Change details

Commit: e98574f

Affected packages:

  • @fluidframework/merge-tree
  • @fluidframework/sequence

⬆️ Table of contents

IContainerRuntimeOptions.flushMode has been removed (#23337)

See 2.12.0 release note

Change details

Commit: fe8279c

Affected packages:

  • @fluidframework/container-runtime

⬆️ Table of contents

ContainerRuntime class is no longer exported (#23341)

Use IContainerRuntime to replace type usages and use the free function loadContainerRuntime to replace usages of the static method ContainerRuntime.loadRuntime.

See the deprecation release note for more details.

Change details

Commit: 61ba06a

Affected packages:

  • @fluidframework/aqueduct
  • @fluid-experimental/attributor
  • @fluidframework/container-runtime
  • @fluidframework/test-utils

⬆️ Table of contents

Replace 'any' in return type for several APIs (#23238)

To improve type safety of the Fluid Framework legacy+alpha API surface, we're moving away from using the any type in favor of unknown.

We mostly expect that any changes required in consumers of these APIs will be limited to having to provide explicit types when calling any of the APIs whose return value changed to unknown, like IFluidSerializer.parse().

So code that looked like this:

// 'myVariable' ended up typed as 'any' here and TypeScript would not do any type-safety checks on it.
const myVariable = this.serializer.parse(stringHeader);

Will now have to look like this:

// Do this if you know the type of the object you expect to get back.
const myVariable = this.serializer.parse(stringHeader) as MyType;

// Alternatively, this will maintain current behavior but also means no type-safety checks will be done by TS.
// const myVariable = this.serializer.parse(stringHeader) as any;

The appropriate type will depend on what the calling code is doing and the objects it expects to be dealing with.

We further encourage consumers of any of these APIs to add runtime checks to validate that the returned object actually matches the expected type.

The list of affected APIs is as follows:

  • IFluidSerializer.encode(...) now takes value: unknown instead of value: any and returns unknown instead of any.
  • IFluidSerializer.decode(...) now takes input: unknown instead of input: any and returns unknown instead of any.
  • IFluidSerializer.stringify(...) now takes value: unknown instead of value: any.
  • IFluidSerializer.parse(...) now returns unknown instead of any.
  • SharedObjectCore.applyStashedOps(...) now takes content: unknown instead of content: any.
  • SharedObjectCore.rollback(...) now takes content: unknown instead of content: any.
  • SharedObjectCore.submitLocalMessage(...) now takes content: unknown instead of content: any.
  • SharedObjectCore.reSubmitCore(...) now takes content: unknown instead of content: any.
  • In SharedObjectCore.newAckBasedPromise<T>(...) the executor parameter now takes reject: (reason?: unknown) instead of reject: (reason?: any).
  • makeHandlesSerializable(...) now returns unknown instead of any.
  • parseHandles(...) now returns unknown instead of any.

Additionally, the following APIs were never designed to return a value and have thus been updated to return void instead of any:

  • SharedObjectCore.processCore(...).
  • SharedObjectCore.onDisconnect(...)

Change details

Commit: 0783a31

Affected packages:

  • @fluidframework/shared-object-base

⬆️ Table of contents

Removed SummarizerStopReason, ISummarizeEventProps, and ISummarizerEvents (#23483)

SummarizerStopReason, ISummarizeEventProps, and ISummarizerEvents have all been removed from the "@fluidframework/container-runtime" package. Please migrate all uses of these APIs to their respective copies in the "@fluidframework/container-runtime-definitions" package.

Change details

Commit: 6666d49

Affected packages:

  • @fluidframework/container-runtime

⬆️ Table of contents

Unknown section: _unknown

# The createDataStoreWithProps APIs on ContainerRuntime and IContainerRuntimeBase have been removed (#22996)

ContainerRuntime.createDataStoreWithProps and IContainerRuntimeBase.createDataStoreWithProps have been removed.

Replace uses of these APIs with PureDataObjectFactory.createInstanceWithDataStore and pass in props via the initialState parameter.

Initial deprecation/removal announcement

The initial deprecations of the now changed or removed types were announced #1537 in Fluid Framework v0.25 #2931

Change details

Commit: bd243fb

Affected packages:

  • @fluidframework/aqueduct
  • @fluidframework/container-runtime
  • @fluidframework/container-runtime-definitions
  • @fluidframework/datastore
  • @fluidframework/runtime-definitions
  • @fluidframework/test-runtime-utils

⬆️ Table of contents

🛠️ Start Building Today!

Please continue to engage with us on GitHub Discussion and Issue pages as you adopt Fluid Framework!

@github-actions github-actions bot changed the title Upcoming release tracking Upcoming Release: FluidFramework v2.2.0 Aug 6, 2024
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.2.0 Upcoming Release: FluidFramework v2.3.0 Aug 17, 2024
CraigMacomber added a commit that referenced this issue Sep 11, 2024
## Description

Fix a couple changesets based on
#22101
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.3.0 Upcoming Release: FluidFramework v2.4.0 Sep 17, 2024
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.4.0 Upcoming Release: FluidFramework v2.5.0 Oct 15, 2024
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.5.0 Upcoming Release: FluidFramework v2.10.0 Nov 5, 2024
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.10.0 Upcoming Release: FluidFramework v2.11.0 Nov 19, 2024
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.11.0 Upcoming Release: FluidFramework v2.12.0 Dec 8, 2024
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.12.0 Upcoming Release: FluidFramework v2.13.0 Dec 19, 2024
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.13.0 Upcoming Release: FluidFramework v2.14.0 Jan 7, 2025
@github-actions github-actions bot changed the title Upcoming Release: FluidFramework v2.14.0 Upcoming Release: FluidFramework v2.20.0 Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant